Evgenii Legotckoi
25 августа 2016 г. 21:04

Qt/C++ - Урок 053. Сборка IBASE SQL драйвера Qt 5.7 на openSUSE Leap 42.1

Установка Qt 5.7 на openSUSE Leap 42.1

Скачиваем последнюю версию Qt для Linux:

  1. wget http://download.qt.io/official_releases/online_installers/qt-unified-linux-x64-online.run

Делаем файл исполняемым

  1. chmod +x qt-unified-linux-x64-online.run

Устанавливаем gcc, make и прочие необходимые библиотеки:

  1. sudo zypper install --type pattern devel_basis

Далее устанавливаем Qt:

  1. ./qt-unified-linux-x64-online.run

Следуем указаниям графического инсталятора. Не забываем отметить пункт Source для установки исходных кодов библиотек.


Сборка IBASE SQL драйвера

Для сборки драйвера необходимы firebird development пакеты. Если они не установлены, то следует выполнить следующие команды для установки данных пакетов.

  1. sudo zypper in libfbclient2-devel

После чего переходим в каталог с исходниками драйвера ibase, которые находятся в папке sql драйверов Qt.

  1. cd <QtPath>/5.7/Src/qtbase/src/plugins/sqldrivers/ibase

После чего редактируем include файл проекта, поскольку в противном случае при сборке будут ошибки об отсутствии библиотек.

  1. vi ../../../sql/drivers/ibase/qsql_ibase.pri

ищем строку

  1. !contains(LIBS, .*gds.*):!contains(LIBS, .*libfb.*):LIBS += -lgds

изменяем ее на следующую

  1. !contains(LIBS, .*gds.*):!contains(LIBS, .*lfb.*):LIBS += -lgds

После этого собираем и устанавливаем драйвер

  1. <QtPath>/Qt/5.7/gcc_64/bin/qmake "INCLUDEPATH+=/usr/include/firebird" "LIBS+=-L/usr/lib64 -lfbclient" ibase.pro
  2. make
  3. make install

Проверка установленных драйверов

Для проверки установленных драйверов можно создать консольный проект Qt, в PRO-файле которого необходимо указать следующие модули Qt:

  1. QT += core sql

main.cpp

Содержимое main.cpp файла будет следующим:

  1. #include <QCoreApplication>
  2. #include <QtSql>
  3.  
  4. int main(int argc, char *argv[])
  5. {
  6. QCoreApplication a(argc, argv);
  7. qDebug() << "Доступные драйверы:" << QSqlDatabase::drivers();
  8.  
  9. return a.exec();
  10. }

Вывод

В выводе qDebug() получаем информацию о доступных драйверах, среди которых должен быть драйвер QIBASE.

  1. Доступные драйверы: ("QIBASE", "QSQLITE", "QMYSQL", "QMYSQL3", "QPSQL", "QPSQL7")

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь