JurijFeb. 9, 2019, 1:03 p.m.

Сборка драйвера MySQL

mysql

Система Windows 10 Версия 1803 Сборка 17134.556

MySQL 8.0.14 - 64

mingw73_64

Qt 5.12.1

Делаю так:


1. В файле f:\Qt\5.12.1\Src\qtbase\src\plugins\sqldrivers\mysql\mysql.pro
закоментировал строку #QMAKE_USE += mysql

2. В файле f:\Qt\5.12.1\Src\qtbase\src\plugins\sqldrivers\qsqldriverbase.pri
исправил строчку на include($$shadowed($$PWD)/configure.pri)

3. Запустил qmake "INCLUDEPATH+=C:\MySQL\include" "LIBS+=C:\MySQL\lib\libmysql.lib" mysql.pro

4. Запустил mingw32-make

5. В папке f:\AppStore\Qt\5.12.1\Src\qtbase\src\plugins\sqldrivers\plugins\sqldrivers\
создались 4 файлика .dll и .a

6. Запустил mingw32-make install

Так же пробывал копировать во все папки, но приложение так и пишет

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabasePrivate::init>> QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
4

Я могу ошибаться, но возможно этот драйер нужно кинуть в каталог Windows, тогда сможет найти. Я с каким-то драйвером с таким сталкивался. Просто пути не может найти к библиотекам.

Более красивого и правильного решения не находил/не делал

Копировал во все папки.

В итоге поставил версию сервера MySQL 5.7.25 - 64 и скопровал из папки MySQL/lib/libmysql.dll в папку сборки проекта, Все заработало.

Удалил qsqlmysql.dll, qsqlmysqld.dll из всех мест куда скопировал поставил обратно версию MySQL ссрвера 8.0.14 - 64, пересобрал проект, все работает.

Скопировал новый файл MySQL 8.0.14 из папки MySQL/lib/libmysql.dll в папку проекта, пересобрал, не работает.

Вернул назад файлик старой версии, оставил как есть.
Не понятно, для чего собирали сами файлики qsqlmysql.dll, qsqlmysqld.dll, получаеться что где-то они нужны а где-то нет?

dll нужны для сборки проекта.

Не берусь судить о конкретной ситуации, вообще не люблю линковку библиотек делать.

Может быть Qt нормально собирается и работает только со старыми библиотеками MySQL, странно очень на самом деле. Хотя если вспомнить, что OpenSSL используется вверсии 1.0.2, то так и не удивительно становится...

R

випадково натрапив на тему, може комусь буде актуально потрбідно додати в environment user path
і навсяк випадок перезавантажити комп (єдиний нюанс в тому що там або в системному path може бути шлях до вашого старого сервера, якщо ви його інсталювали, а не як я просто використовував архів)
G:\my\mysql-8.0.17-winx64\bin
G:\my\mysql-8.0.17-winx64\lib

білдав драйвер під msvc2017_64 через креатор, просто додавши в Build Steps -> Additional arguments: -- MYSQL_INCDIR=G:/my/mysql-8.0.17-winx64/include "MYSQL_LIBDIR=G:/my/mysql-8.0.17-winx64/lib"

Comments

Only authorized users can post comments.
Please, Log in or Sign up
How to become an author?

Contribute to the evolution of the EVILEG community.

Learn how to become a site author.

Learn it
Donate

Good day, Dear Users!!!

I am Evgenii Legotckoi, developer of EVILEG. And it is my hobby project, which helps to learn programming another programmers and developers

If the site helped you, and you want also support the development of the site, than you can donate by following ways

PayPalYandex.Money
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
KA

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

  • Result:78points,
  • Rating points2
R

C++ - Test 002. Constants

  • Result:75points,
  • Rating points2
R

C++ - Test 001. The first program and data types

  • Result:73points,
  • Rating points1
Last comments
V

Django - Tutorial 027. Implementation Google reCAPTCHA

Спасибо. Только использую декоратор не в urls.py а перед views
R

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Вы меня не совсем правильно поняли, но все равно спасибо, принял все к сведению. Все сделал как вы сказали, все отлично работает, еще раз огромнейшее спасибо) Разве что только что были опять про…

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Стоило перед использованием что ли инструкцию прочитать https://www.cyberforum.ru/blogs/131347/blog2457.html "После сборки при запуске требовались dll," Ясное дело стоило задепло…
R
R

Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

Да, собралось. После сборки при запуске требовались dll, перекинул всю папки bin, plugins(не знаю как можно было сделать более умно). Как я понял в первой строке путь к екзешнику вставляю, втор…
Now discuss on the forum
C

Счечик производительности сети

Здравствуйте! Я решил проблему используя QtNetworkMonitor пример с GitHub . Вопрос закрыт.

Вопрос по указателям в с++

Как то это все усложняет. Еще вероятно работает так: void v(xxx *x3){ x2=x3;}

Как в Qt сохранить файл в папку загрузок в Android

Вызывайте эту функцию или в самом начале, или когда нужно сохранять файлы. Она дает права доступа для записи.

QML+QtGraphicalEffects

да, сборку делал без параметра поиска qml, хотя dll QtGraphicalEffects он подтягивает, когда я добавил всю папку QtGraphicalEffects в проект - то заработало, похоже что именно qml-файлов ему не …

Не работают слоты/сигналы

и посмотрите работу с потоками в Qt, там подробно описано как передавать данные с одного в потока в другой при помощи сигналов и слотов
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB