IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bases de données Discussion :

Accéder à une base de données MySQL avec Connector C++


Sujet :

Bases de données

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    avril 2007
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : avril 2007
    Messages : 211
    Points : 137
    Points
    137
    Par défaut Accéder à une base de données MySQL avec Connector C++
    Bonjour,

    Je suis sure que ce poste a déjà du être posté 1000x. J'ai fait plein de recherche sur internet dans les formes mais jusqu'à présent tout ce que j'ai pu testé ne fonctionne pas.

    Mon bute est d'utiliser mysql dans QT.

    J'ai d'abord testé "QMYSQL" utilisant divers tuto. A la fin ca compile mais j'ai cette erreur:
    QSqlDatabase: QMYSQL driver not loaded
    D'après ce que j'ai lu dans les forum c'est libmysql.dll et/ou libmysql.lib qui doit être copié dans un dossier spécifique.
    Je l'ai copié dans divers dossiers selon les forms que j'ai consulté. Rien a faire ca ne fonctionne pas.

    J'ai donc opté pour ne pas utiliser QMYSQL mais utiliser Connector C++. Je l'utilise dans un programme c++ sous linux qui ne fait pas intervenir QT et ca fonctionne.
    Je me suis dit je vais essayer de faire quelque chose que je connais un peu.
    Et j'ai trouvé un tuto qui explique comment faire ca dans QT.
    J'ai du le modifié pour enlever quelques erreurs de compilation mais la je suis bloqué avec une erreur de compilation que je n'arrive pas à surmonter.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
    #-------------------------------------------------
    #
    # Project created by QtCreator 2021-10-26T10:08:09
    #
    #-------------------------------------------------
     
    QT       += core gui
     
    greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
     
    TARGET = DataBaseTest
    TEMPLATE = app
     
    INCLUDEPATH += 'C:\Program Files\MySQL\Connector C++ 8.0\include\jdbc'
    LIBS += -L'C:\Program Files\MySQL\Connector C++ 8.0\lib64\vs14 -lmysqlcppconn'
     
    # The following define makes your compiler emit warnings if you use
    # any feature of Qt which as been marked as deprecated (the exact warnings
    # depend on your compiler). Please consult the documentation of the
    # deprecated API in order to know how to port your code away from it.
    DEFINES += QT_DEPRECATED_WARNINGS
     
    # You can also make your code fail to compile if you use deprecated APIs.
    # In order to do so, uncomment the following line.
    # You can also select to disable deprecated APIs only up to a certain version of Qt.
    #DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0
     
     
    SOURCES += main.cpp\
            mainwindow.cpp
     
    HEADERS  += mainwindow.h
     
    FORMS    += mainwindow.ui

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
     
    #include "mainwindow.h"
    #include "ui_mainwindow.h"
     
    #include <cppconn/connection.h>
    #include <cppconn/prepared_statement.h>
    #include <cppconn/driver.h>
    #include <cppconn/exception.h>
    #include <cppconn/resultset.h>
     
    MainWindow::MainWindow(QWidget *parent) :
        QMainWindow(parent),
        ui(new Ui::MainWindow)
    {
        ui->setupUi(this);
     
     
    ///////////////////////////
        sql::Driver *driver;
        sql::Connection *connection;
     
        try{
              driver=get_driver_instance();
              connection=driver->connect("localhost",
                                "mano", "mano");
              connection->setAutoCommit(0);
              connection->setSchema("addressbook");
     
           }catch (sql::SQLException &ex) {
    //          cout<<"Exception occurred"<<ex.getErrorCode()<<endl;
           }
     
     
     //res = stmt->executeQuery("SELECT * FROM Animal");
     
           sql::PreparedStatement *pstmt=connection->prepareStatement("SELECT * FROM Addresses");
           sql::ResultSet *resultSet=NULL;
           try{
              resultSet=pstmt->executeQuery();
              while(resultSet->next()){
                 //Person p;
                 int id = resultSet->getInt("addressId");
                 QString firstName = QString::fromStdString(resultSet->getString("firstName"));
                 QString lastName = QString::fromStdString(resultSet->getString("lastName"));
                 QString email = QString::fromStdString(resultSet->getString("email"));
                 QString phoneNumber = QString::fromStdString(resultSet->getString("phoneNumber"));
                 //list.append(p);
              }
           }catch(sql::SQLException &ex){
    //          cout<<"Exception occurred"<<ex.getErrorCode()<<endl;
     
           resultSet->close();
           pstmt->close();
           delete pstmt;
           delete resultSet;
           //return list;
        }
     
    }
    Voici l'erreur de compilation:
    D:\Thomas_2nd\QT\build-DataBaseTest-Desktop_Qt_5_8_0_MinGW_32bit-Debug\debug\mainwindow.o:-1: In function `check_lib':

    C:\Program Files\MySQL\Connector C++ 8.0\include\jdbc\cppconn\driver.h:77: erreur : undefined reference to `check(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)'

    C:\Program Files\MySQL\Connector C++ 8.0\include\jdbc\cppconn\driver.h:78: erreur : undefined reference to `check(std::map<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >, std::less<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > >, std::allocator<std::pair<std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > > > > const&)'


    D:\Thomas_2nd\QT\build-DataBaseTest-Desktop_Qt_5_8_0_MinGW_32bit-Debug\debug\mainwindow.o:-1: In function `get_driver_instance_by_name':

    C:\Program Files\MySQL\Connector C++ 8.0\include\jdbc\cppconn\driver.h:90: erreur : undefined reference to `_get_driver_instance_by_name'

    collect2.exe:-1: erreur : error: ld returned 1 exit status

    Quelqu'un aurait il une idée de comment corriger cette erreur ?

    Merci d'avance
    Dereck

  2. #2
    Responsable Qt & Livres


    Avatar de dourouc05
    Homme Profil pro
    Ingénieur de recherche
    Inscrit en
    août 2008
    Messages
    26 280
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur de recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : août 2008
    Messages : 26 280
    Points : 186 056
    Points
    186 056
    Par défaut


    Pour les deux premières erreurs, peut-être ton compilateur est-il trop vieux ou faut-il ajouter un paramètre pour compiler en C++11 ?

    Pour la suivante, j'ai des doutes sur cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LIBS += -L'C:\Program Files\MySQL\Connector C++ 8.0\lib64\vs14 -lmysqlcppconn'
    L'apostrophe ne délimite-t-elle pas simplement un chemin, sans la bibliothèque à ajouter ? Je pense à quelque chose comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    LIBS += -L'C:\Program Files\MySQL\Connector C++ 8.0\lib64\vs14' -lmysqlcppconn
    Pour ce qui est de l'installation du pilote MySQL, tu dois copier qmysql.dll dans le dossier sqldrivers à côté de ton exécutable, puis ajouter libmysql.dll (à côté de ton exécutable, de mémoire). Fais attention à bien prendre le même compilateur pour Qt, ton application et le pilote MySQL, sinon ça ne chargera pas (par exemple, tout doit venir de C:\Qt\5.15.0\msvc2019_64 : Qt du dossier bin, qmysql.dll de plugins/sqldrivers).
    Vous souhaitez participer aux rubriques Qt (tutoriels, FAQ, traductions) ou HPC ? Contactez-moi par MP.

    Créer des applications graphiques en Python avec PyQt5
    Créer des applications avec Qt 5.

    Pas de question d'ordre technique par MP !

Discussions similaires

  1. Réponses: 10
    Dernier message: 10/06/2009, 13h26
  2. Réponses: 11
    Dernier message: 21/05/2008, 12h20
  3. Problème de copie d'une base de données MySQL avec PHP
    Par rheem dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 15/10/2007, 14h52
  4. Réponses: 3
    Dernier message: 19/09/2006, 15h36
  5. Peut on lier une base de donnée Mysql avec MS Project
    Par casper24 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 06/04/2006, 22h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo