Qt Forum

    • Login
    • Search
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Search
    • Unsolved

    Selecting data from mysql using qt?

    General and Desktop
    7
    150
    97381
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      tony last edited by

      Did you leave

      @
      //bool ok = db.open();
      @

      commented?

      1 Reply Last reply Reply Quote 0
      • D
        doforumda last edited by

        well i changed my code to this and added lastError as well

        @
        #include <QApplication>
        #include <QSqlDatabase>
        #include <QSqlError>
        #include <QSqlQuery>
        #include <QDebug>
        #include <QString>
        #include <QVariant>
        //#include <QtCore>
        //#include <QtSql>
        //#include "../connection.h"
        #include "db.h"

        int main(int argc, char *argv[])
        {
        QCoreApplication a(argc, argv);

        QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
        db.setDatabaseName("testTwo");
        db.setUserName("root");
        db.setPassword("");
        db.setHostName("localhost");
        
        //bool ok = db.open();
        
        QSqlQuery query;
        query.exec&#40;"SELECT firstname,lastname FROM testTable"&#41;;
        while(query.next()) {
            QString firstName = query.value(0).toString();
            QString secondName = query.value(1).toString();
            qDebug() << "First Name: " << firstName << "Last Name:" << secondName;
            qDebug() << db.lastError();
        }
        return a.exec&#40;&#41;;
        

        }
        @

        it still says QSqlQuery::exec: database not open

        1 Reply Last reply Reply Quote 0
        • D
          doforumda last edited by

          it is still as commented
          [quote author="Antonio Di Monaco" date="1286818410"]Did you leave

          @
          //bool ok = db.open();
          @

          commented?[/quote]

          1 Reply Last reply Reply Quote 0
          • D
            Dmytro last edited by

            Try uncomment line 23

            1 Reply Last reply Reply Quote 0
            • D
              doforumda last edited by

              i uncomment line 23 and comment everything below line 23 then it just says
              @
              Starting /home/zafar/c++/dbExample-build-desktop/dbExample...
              @

              and stucks there

              1 Reply Last reply Reply Quote 0
              • D
                Dmytro last edited by

                OH! You use SQL code before
                a.exec()
                !
                Are you sure?

                Create standart QT GUI application and wrote sql code in mainwindow module.

                1 Reply Last reply Reply Quote 0
                • D
                  doforumda last edited by

                  i am new to qt. how can i create Qt Gui App and do you mean i should write sql code in mainwindow.h file?

                  1 Reply Last reply Reply Quote 0
                  • D
                    doforumda last edited by

                    right now i have three files. db.h, db,cpp and main.cpp

                    1 Reply Last reply Reply Quote 0
                    • D
                      Dmytro last edited by

                      Run QT Creator.
                      Use menu File/new file or project.
                      Select QT Gui application.
                      ...
                      and select SQL checkbox
                      ...
                      and write sql code in MainWindow.cpp
                      ...
                      and see SQL Example please

                      1 Reply Last reply Reply Quote 0
                      • D
                        doforumda last edited by

                        well i tried "File/new file or project and select qt gui app" but i ddint find any sql checkbox anywhere in creating new project

                        1 Reply Last reply Reply Quote 0
                        • D
                          Dmytro last edited by

                          no coments...
                          How can I send you screenshot?

                          1 Reply Last reply Reply Quote 0
                          • D
                            doforumda last edited by

                            you can add pictures here as screenshots or if you want my email address i ll give you that as well for screenshots

                            1 Reply Last reply Reply Quote 0
                            • D
                              doforumda last edited by

                              anyone who can help?

                              1 Reply Last reply Reply Quote 0
                              • D
                                Dmytro last edited by

                                !http://hin.dp.ua/files/down/qt_scr.PNG(my screenshot)!

                                1 Reply Last reply Reply Quote 0
                                • D
                                  doforumda last edited by

                                  well i dont have that option. here is what i get
                                  when i click file/new file or project then this screenshot
                                  "Your text to link here...":http://www.freeimagehosting.net/uploads/702f633ae7.png
                                  then i keep clicking next getting the follwoing screenshots
                                  "Your text to link here...":http://www.freeimagehosting.net/uploads/ab872acfb8.png
                                  "Your text to link here...":http://www.freeimagehosting.net/uploads/45c51ab364.png
                                  "Your text to link here...":http://www.freeimagehosting.net/uploads/84605eae46.png
                                  "Your text to link here...":http://www.freeimagehosting.net/uploads/84605eae46.png

                                  1 Reply Last reply Reply Quote 0
                                  • D
                                    Dii last edited by

                                    Well, it should make no problem to have SQL query before exec(), at least I don't have any problem with that.

                                    Let's get back to square one:
                                    You said if you uncomment the
                                    @bool ok = db.open();@
                                    then your program hangs. Can we see the value of 'ok'?
                                    @qDebug() << ok;@
                                    My guess is probably you have problems granting the rights in mysql when you've created the table... have you made
                                    @GRANT ALL ON testTwo.* to 'root'at'localhost' IDENTIFIED BY 'somepassword';@
                                    (Ouch please replace the 'at' with the 'at' sign, the forum motor uses it for code tags, I don't know how to write it... I hope it's not confusing.
                                    I'm not sure if you can do it with empty password, I guess yes, but I never do that.)

                                    1 Reply Last reply Reply Quote 0
                                    • D
                                      doforumda last edited by

                                      i now put password for root at localhost.
                                      when i place qDebug() << ok then it displays this
                                      @
                                      false
                                      QSqlQuery::exec: database not open
                                      @

                                      false might be the value of ok.

                                      1 Reply Last reply Reply Quote 0
                                      • L
                                        lyuts last edited by

                                        Are you able to connect to your DB from shell?

                                        I'm a rebel in the S.D.G.

                                        1 Reply Last reply Reply Quote 0
                                        • D
                                          doforumda last edited by

                                          i dont know how to connect to my DB from shell. I install xampp which is easy for me to manage my databases.
                                          how can i connect from shell?

                                          1 Reply Last reply Reply Quote 0
                                          • L
                                            lyuts last edited by

                                            @mysql -h host -D dbname -u user@

                                            I guess your can omit host parameter if you are connecting to localhost. You might need to specify "-p password" switch also (depends on mysql configuration).

                                            I'm a rebel in the S.D.G.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post