Ruslan Polupan
30 травня 2018 р. 14:01

Встановлення драйвера QIBASE (Firebird) Qt 5.11 Suse LEAP 42.3

Вирішив оновити Qt. Щоразу це тягне за собою перевстановлення драйверів для роботи з базами даних.

Вирішив записати послідовність дій.

Сподіваюся заощаджу комусь пару годин. :-)


Встановлюємо Qt 5.11.

У документації з Qt сказано:

> Як створити плагін QIBASE на Unix та macOS
>
> Припускається, що InterBase або Firebird встановлено в /opt/interbase:
>
> Якщо ви використовуєте Firebird, бібліотека Firebird має бути встановлена явно:
>
> cd $QTDIR/qtbase/src/plugins/sqldrivers
> qmake -- IBASE_PREFIX=/opt/interbase IBASE_LIBS=-lfbclient
> зробити підоснови
>
>
>

Але все не так просто.

Вивчаємо SuSE, заголовні файли Fierbird знаходяться у /usr/include/firebird.

Для того щоб запускався qmake необхідно додати в .bashrc

PATH=$PATH:~/Qt5.11.0/5.11.0/gcc_64/bin
export PATH

Перелогінюємося або відкриваємо нову консоль.

Переходимо до папки з драйверами.

cd ~/Qt5.11.0/5.11.0/Src/qtbase/src/plugins/sqldrivers

Тепер на відміну від документації:

qmake -- IBASE_INCDIR=/usr/include/firebird IBASE_LIBS=-lfbclient

якщо робити як зазначено у документації нічого не відбувається :-)

Отримуємо таке:

Info: creating stash file /home/rust/Qt5.11.0/5.11.0/Src/qtbase/src/plugins/sqldrivers/.qmake.stash                                                                                                                

Running configuration tests...                                                                                                                                                                                     
Checking for DB2 (IBM)... no                                                                                                                                                                                       
Checking for InterBase... yes                                                                                                                                                                                      
Checking for MySQL... yes                                                                                                                                                                                          
Checking for OCI (Oracle)... no                                                                                                                                                                                    
Checking for ODBC... no                                                                                                                                                                                            
Checking for PostgreSQL... no                                                                                                                                                                                      
Checking for SQLite (version 2)... no                                                                                                                                                                              
Checking for TDS (Sybase)... no                                                                                                                                                                                    
Done running configuration tests.                                                                                                                                                                                  

Configure summary:                                                                                                                                                                                                 

Qt Sql:                                                                                                                                                                                                            
 DB2 (IBM) .............................. no                                                                                                                                                                      
 InterBase .............................. yes                                                                                                                                                                     
 MySql .................................. yes                                                                                                                                                                     
 OCI (Oracle) ........................... no                                                                                                                                                                      
 ODBC ................................... no
 PostgreSQL ............................. no
 SQLite2 ................................ no
 SQLite ................................. yes
   Using system provided SQLite ......... no
 TDS (Sybase) ........................... no

Qt is now configured for building. Just run 'make'.
Once everything is built, Qt is installed.
You should NOT run 'make install'.
Note that this build cannot be deployed to other machines or devices.

Prior to reconfiguration, make sure you remove any leftovers from
the previous build.

Для драйвера Interbase готова конфігурація.

Далі...

make sub-ibase

При компіляції отримуємо помилку:

g++: error: unrecognized command line option ‘-std=c++1z’
g++: error: unrecognized command line option ‘-Wdate-time’

Можна по гуглити.

Переходимо до каталогу ibase.

Відкриваємо у редакторі Makefile.

У двох місцях міняємо -std=c++1z на -std=c++11.

І в цих рядках видаляємо -Wdate-time.

Зберігаємо файл.

Переходимо на каталог вище та повторюємо:

make sub-ibase

**Ура! Він зібрався.

Тепер би його ще проінсталювати...

make sub-ibase-install_subtargets

Можна користуватися драйвером.

Ось такі танці з бубнами.

По статті запитували0питання

1

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up