Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Selecting data from mysql using qt?
Forum Updated to NodeBB v4.3 + New Features

Selecting data from mysql using qt?

Scheduled Pinned Locked Moved General and Desktop
150 Posts 7 Posters 142.7k Views 1 Watching
  • 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.
  • D Offline
    D Offline
    doforumda
    wrote on 12 Oct 2010, 09:51 last edited by
    #65

    you mean like this
    grant all on testTwo.* to root@localhost ;
    if yes it also displaying same error

    1 Reply Last reply
    0
    • D Offline
      D Offline
      Dii
      wrote on 12 Oct 2010, 09:52 last edited by
      #66

      so, here we go:

      grant all on testTwo.* to 'root'@'localhost' identified by 'password';

      Make the right apostrophes! :) You have to set the password in your Qt app too.

      1 Reply Last reply
      0
      • D Offline
        D Offline
        Dii
        wrote on 12 Oct 2010, 09:52 last edited by
        #67

        ok, wait I see

        1 Reply Last reply
        0
        • D Offline
          D Offline
          Dii
          wrote on 12 Oct 2010, 09:53 last edited by
          #68

          the Devnet's forum motor changes the apostrophes somehow... use the straight apostrophes everywhere
          I mean this @'@

          1 Reply Last reply
          0
          • D Offline
            D Offline
            doforumda
            wrote on 12 Oct 2010, 10:01 last edited by
            #69

            mysql query did its job its now successful but when i use qt code and try to make it run it displays same error

            @
            Starting /home/zafar/c++/dbExample-build-desktop/dbExample...
            false
            QSqlQuery::exec: database not open
            /home/zafar/c++/dbExample-build-desktop/dbExample exited with code 0
            @

            1 Reply Last reply
            0
            • D Offline
              D Offline
              doforumda
              wrote on 12 Oct 2010, 10:02 last edited by
              #70

              wait i think the query is not sucessful because it displays this message 0 rows affected
              @
              mysql> grant all on testTwo.* to 'root'at'localhost' identified by 'password';
              Query OK, 0 rows affected (0.01 sec)
              @

              1 Reply Last reply
              0
              • L Offline
                L Offline
                lyuts
                wrote on 12 Oct 2010, 10:03 last edited by
                #71

                Add this to your code after connecting:

                @qDebug() << db.lastError().text();@

                And tell us what the error is.

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

                1 Reply Last reply
                0
                • L Offline
                  L Offline
                  lyuts
                  wrote on 12 Oct 2010, 10:04 last edited by
                  #72

                  [quote author="doforumda" date="1286877766"]wait i think the query is not sucessful because it displays this message 0 rows affected
                  @
                  mysql> grant all on testTwo.* to 'root'at'localhost' identified by 'password';
                  Query OK, 0 rows affected (0.01 sec)
                  @[/quote]

                  Did you run that command with 'password' instead of '123456'?

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

                  1 Reply Last reply
                  0
                  • D Offline
                    D Offline
                    Dii
                    wrote on 12 Oct 2010, 10:05 last edited by
                    #73

                    0 rows is just fine with the grant command... have you set the password on

                    @db.setPassword("password");@

                    ?

                    1 Reply Last reply
                    0
                    • D Offline
                      D Offline
                      doforumda
                      wrote on 12 Oct 2010, 10:09 last edited by
                      #74

                      this is the output after adding lastError.text()
                      @
                      Starting /home/zafar/c++/dbExample-build-desktop/dbExample...
                      " "
                      false
                      QSqlQuery::exec: database not open
                      /home/zafar/c++/dbExample-build-desktop/dbExample exited with code 0
                      @

                      lyut: yes i use command with 'password' not '123456'

                      Dii sorry i didnt understand this db.setPassword("password");
                      where should i set this

                      1 Reply Last reply
                      0
                      • L Offline
                        L Offline
                        lyuts
                        wrote on 12 Oct 2010, 10:13 last edited by
                        #75

                        [quote author="doforumda" date="1286878193"]
                        lyut: yes i use command with 'password' not '123456'

                        Dii sorry i didnt understand this db.setPassword("password");
                        where should i set this[/quote]

                        1. I assume you should have specified the actual password when running that query.
                        2. @db.setPassword("password");@ should be added to your source code just where you set db options.

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

                        1 Reply Last reply
                        0
                        • D Offline
                          D Offline
                          doforumda
                          wrote on 12 Oct 2010, 10:15 last edited by
                          #76

                          i ran query again with actual password
                          i have already setup password in my qt code here it is
                          @
                          #include <QApplication>
                          #include <QtSql>

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

                          QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
                          db.setDatabaseName("testTwo");
                          db.setUserName("root");
                          db.setPassword("123456");
                          db.setHostName("localhost");
                          
                          qDebug() << db.lastError().text();
                          
                          bool ok = db.open();
                          qDebug() << ok;
                          
                          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 0;
                          

                          }

                          @

                          1 Reply Last reply
                          0
                          • D Offline
                            D Offline
                            Dii
                            wrote on 12 Oct 2010, 10:18 last edited by
                            #77

                            db.lasterror().text() should come after line 16 (db.open()).
                            The password in the Qt code must be the same what you have specified in the GRANT command above.

                            I suspect probably, you haven't made the database and the table in mysql yet, if you go back to mysql command line, what do you get by these commands:

                            @SHOW databases;

                            USE testTwo;

                            SHOW tables;@

                            I go to dinner, be back in a few minutes :)

                            1 Reply Last reply
                            0
                            • L Offline
                              L Offline
                              lyuts
                              wrote on 12 Oct 2010, 10:21 last edited by
                              #78

                              You put my debug before opening the connection. Put it after.

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

                              1 Reply Last reply
                              0
                              • D Offline
                                D Offline
                                doforumda
                                wrote on 12 Oct 2010, 10:24 last edited by
                                #79

                                i changed db.lastError().text(); and place it after db.open()
                                this is the output
                                @
                                Starting /home/zafar/c++/dbExample-build-desktop/dbExample...
                                "Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) QMYSQL: Unable to connect"
                                false
                                QSqlQuery::exec: database not open
                                /home/zafar/c++/dbExample-build-desktop/dbExample exited with code 0
                                @

                                the commands in mysql displayed are here
                                repectively to your commands

                                @
                                mysql> show databases;
                                +--------------------+
                                | Database |
                                +--------------------+
                                | information_schema |
                                | cdcol |
                                | mysql |
                                | phpmyadmin |
                                | test |
                                | testTwo |
                                +--------------------+
                                6 rows in set (0.01 sec)

                                mysql> use testTwo
                                Database changed
                                mysql> show tables
                                -> ;
                                +-------------------+
                                | Tables_in_testTwo |
                                +-------------------+
                                | testTable |
                                +-------------------+
                                1 row in set (0.01 sec)

                                @

                                1 Reply Last reply
                                0
                                • D Offline
                                  D Offline
                                  doforumda
                                  wrote on 12 Oct 2010, 10:38 last edited by
                                  #80

                                  any clues?

                                  1 Reply Last reply
                                  0
                                  • L Offline
                                    L Offline
                                    lyuts
                                    wrote on 12 Oct 2010, 10:41 last edited by
                                    #81

                                    Change the 19th line to

                                    @QSqlQuery query(db);@

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

                                    1 Reply Last reply
                                    0
                                    • D Offline
                                      D Offline
                                      doforumda
                                      wrote on 12 Oct 2010, 10:43 last edited by
                                      #82

                                      same error again

                                      1 Reply Last reply
                                      0
                                      • L Offline
                                        L Offline
                                        lyuts
                                        wrote on 12 Oct 2010, 10:46 last edited by
                                        #83

                                        Take a look into mysql logs to see what happens when you are trying to connect from your application.

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

                                        1 Reply Last reply
                                        0
                                        • D Offline
                                          D Offline
                                          doforumda
                                          wrote on 12 Oct 2010, 10:49 last edited by
                                          #84

                                          how can i check that mysql logs and from where?

                                          1 Reply Last reply
                                          0

                                          74/150

                                          12 Oct 2010, 10:09

                                          • Login

                                          • Login or register to search.
                                          74 out of 150
                                          • First post
                                            74/150
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • Users
                                          • Groups
                                          • Search
                                          • Get Qt Extensions
                                          • Unsolved