Юрий
Feb. 10, 2019, 12:03 a.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

3

Do you like it? Share on social networks!

4
Evgenii Legotckoi
  • Feb. 11, 2019, 3:20 p.m.
  • The answer was marked as a solution.

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

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

    Юрий
    • Feb. 11, 2019, 9:41 p.m.

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

    В итоге поставил версию сервера 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, получаеться что где-то они нужны а где-то нет?

      Evgenii Legotckoi
      • Feb. 12, 2019, 12:55 p.m.
      • (edited)

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

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

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

        R
        • Aug. 5, 2019, 4:39 p.m.

        випадково натрапив на тему, може комусь буде актуально потрбідно додати в 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
          • Last comments
          • AK
            April 1, 2025, 11:41 a.m.
            Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
          • Evgenii Legotckoi
            March 9, 2025, 9:02 p.m.
            К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
          • VP
            March 9, 2025, 4:14 p.m.
            Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
          • ИМ
            Nov. 22, 2024, 9:51 p.m.
            Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
          • Evgenii Legotckoi
            Oct. 31, 2024, 11:37 p.m.
            Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup