Михаиллл
МихаилллЖел. 9, 2018, 8:25 Т.Ж.

Как в QT подключить PostgreSQL

Qt, PostgreSQL

Здравствуйте.
Пытаюсь подключить PostgreSQL 9,6. Разрядность скорей всего 32.
Компилятор MinGW32.
В pro файле дописал
INCLUDEPATH += C:/Program Files (x86)/PostgreSQL/9.6/include
LIBS+= C:/Program Files (x86)/PostgreSQL/9.6/lib/libpq.dll
В проекте срр написал
QSqlDatabase SearchDB = QSqlDatabase::addDatabase("QPSQL");
При работе выдает ошибку:
QSqlDatabase: QPSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7
Скажите пожалуйста как правильно подключить PostgreSQL 9,6?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

8
Evgenii Legotckoi
  • Жел. 9, 2018, 10:14 Т.Ж.

Непонятно, вы драйвер скачали или собирали?

Сдаётся мне, что возможно более правильный вариант собрать своим компилятором вначале его, а потом уже подключать.

    Михаиллл
    • Жел. 10, 2018, 6:59 Т.Ж.

    оказывается новый драйвер не нужен, так работает:
    https://forum.qt.io/topic/81148/cannot-install-postgresql-driver/8

      Михаиллл
      • Жел. 10, 2018, 7:29 Т.Ж.

      С драйвером проблема решена.
      Но дальше пытаюсь подключиться к базе.
      На этом этапе

      QSqlDatabase SearchDB = QSqlDatabase::addDatabase("QPSQL");
          SearchDB.setDatabaseName("CVReader");
          SearchDB.setUserName("postgres");
          SearchDB.setHostName("localhost");
          SearchDB.setPassword("1qaz");
      if (!SearchDB.open()) {qDebug()<<"bd is open";} else {qDebug()<<"bd not open";}
      

      дебаг говорит что база открыта.
      Если дальше делать подключение к таблице

      QSqlTableModel *SearchTableModel = new QSqlTableModel(this);
          SearchTableModel ->setTable("ResumePostgresSQL");
      SearchTableModel->setHeaderData(1,Qt::Horizontal, "Название столбца");
       SearchTableModel->select(); 
      

      то выдает ошибку:
      QSqlDatabasePrivate::database: unable to open database: "could not connect to server: Connection refused (0x0000274D/10061)\n\tIs the server running on host \"localhost\" (::1) and accepting\n\tTCP/IP connections on port 5432?\ncould not connect to server: Connection refused (0x0000274D/10061)\n\tIs the server running on host \"localhost\" (127.0.0.1) and accepting\n\tTCP/IP connections on port 5432?\nQPSQL: Unable to connect"
      Скажите пожалуйста, как правильно подключить эту субд?

        Михаиллл
        • Жел. 10, 2018, 7:50 Т.Ж.
        • (өңделген)

        извините ошибся, на SearchDB.open() база не открывается.
        может быть setHostName нужен другой?

          Evgenii Legotckoi
          • Жел. 10, 2018, 7:51 Т.Ж.

          Насколько помню, там нужно ещё порты укзаывать, если подключение идёт к сетевой базе данных и вместо localhost нужно указать ip адрес, в вашем случае "127.0.0.1"

            Evgenii Legotckoi
            • Жел. 10, 2018, 7:56 Т.Ж.

            так вроде бы

            SearchDB.setHostName( "192.168.0.1" );
            SearchDB.setPort( 5432 );
            
              Михаиллл
              • Жел. 10, 2018, 8:03 Т.Ж.

              Спасибо.
              Дописал так и база открылась

                  SearchDB.setHostName("127.0.0.1");
                  SearchDB.setPort(5434);
              

              Но QSqlTableModel не отображает запрашиваемую таблицу.

                Evgenii Legotckoi
                • Жел. 10, 2018, 8:10 Т.Ж.

                Это уже другой, отдельный вопрос )))

                Скорее всего неправильно объявлено что-то в таблице, либо она не создана, либо неправильно читается. Смотрите вывод ошибок

                  Пікірлер

                  Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                  Кіріңіз немесе Тіркеліңіз
                  m
                  • molni99
                  • Қаз. 26, 2024, 1:37 Т.Ж.

                  C++ - Тест 004. Указатели, Массивы и Циклы

                  • Нәтиже:80ұпай,
                  • Бағалау ұпайлары4
                  m
                  • molni99
                  • Қаз. 26, 2024, 1:29 Т.Ж.

                  C++ - Тест 004. Указатели, Массивы и Циклы

                  • Нәтиже:20ұпай,
                  • Бағалау ұпайлары-10

                  C++ - Тест 003. Условия и циклы

                  • Нәтиже:42ұпай,
                  • Бағалау ұпайлары-8
                  Соңғы пікірлер
                  i
                  innorwallҚар. 10, 2024, 3:52 Т.Қ.
                  Qt/C++ - 025-сабақ. Qmake утилитасымен құрастыру үшін жоба файлдарын жасау where to buy priligy It helps keep bones strong, nerves and muscles working properly, and blood sugar under control
                  i
                  innorwallҚар. 10, 2024, 1:03 Т.Қ.
                  Джанго - Сабақ 029. Сайтқа жеке хабарламалар мен чаттар қосу - 1 бөлім priligy at walgreens ortho ciprofloxacin tablet uses in telugu Republicans in Congress have chastised Obama s top health adviser, Health and Human Services Secretary Kathleen Sebelius, …
                  i
                  innorwallҚар. 10, 2024, 9:55 Т.Ж.
                  Linux жүйесінде файлдарды қалай көшіруге болады In dogs, it is used to facilitate synchronized cardioversion of atrial fibrillation buy priligy usa
                  i
                  innorwallҚар. 10, 2024, 9:03 Т.Ж.
                  Qt тілінде ойын қалай жазылады - 3-сабақ. Басқа объектілермен әрекеттесу priligy otc I routinely do not tell patients and or parents of patients with atopic dermatitis to avoid glutamates in food
                  Енді форумда талқылаңыз
                  i
                  innorwallҚар. 10, 2024, 4:34 Т.Қ.
                  добавить qlineseries в функции priligy dapoxetine amazon a Rates of overall CRA in respect of associated explanatory variables age at treatment and age at menarche
                  9
                  9AnonimҚаз. 25, 2024, 9:10 Т.Ж.
                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                  F
                  FynjyШілде 22, 2024, 4:15 Т.Ж.
                  при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                  Бізді әлеуметтік желілерде бақылаңыз