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 159.9k 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.
  • L Offline
    L Offline
    lyuts
    wrote on 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 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 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 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 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 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 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 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 last edited by
                    #80

                    any clues?

                    1 Reply Last reply
                    0
                    • L Offline
                      L Offline
                      lyuts
                      wrote on 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 last edited by
                        #82

                        same error again

                        1 Reply Last reply
                        0
                        • L Offline
                          L Offline
                          lyuts
                          wrote on 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 last edited by
                            #84

                            how can i check that mysql logs and from where?

                            1 Reply Last reply
                            0
                            • L Offline
                              L Offline
                              lyuts
                              wrote on last edited by
                              #85

                              [quote author="doforumda" date="1286880547"]how can i check that mysql logs and from where? [/quote]

                              Try to find them:
                              @find /opt/lampp -name log -type d@

                              When you find the log directory, find a log for mysql and use tail utility:

                              @tail -f /path/to/mysql.log@

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

                              1 Reply Last reply
                              0
                              • D Offline
                                D Offline
                                doforumda
                                wrote on last edited by
                                #86

                                this command didnt return something
                                @
                                root@zafar-laptop:/# find /opt/lampp -name log -type d
                                root@zafar-laptop:/#
                                @

                                1 Reply Last reply
                                0
                                • D Offline
                                  D Offline
                                  doforumda
                                  wrote on last edited by
                                  #87

                                  i have a folder inside lampp with the name logs. is it the one which your are talking about

                                  1 Reply Last reply
                                  0
                                  • L Offline
                                    L Offline
                                    lyuts
                                    wrote on last edited by
                                    #88

                                    Solution 1:
                                    @find /opt/lampp -name '*.log'@
                                    This might need sudo'ing.

                                    Solution 2:
                                    If 1st fails then you need to find the config files for mysql (it should be located in /opt/lampp directory) and try to find out what is the location of mysql's log files.

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

                                    1 Reply Last reply
                                    0
                                    • D Offline
                                      D Offline
                                      doforumda
                                      wrote on last edited by
                                      #89

                                      there are 6 files in there but no mysql.log

                                      these are the files
                                      access_log, cgisock.1693, error_log, httpd.pid, php_error_log, ssl_request_log

                                      1 Reply Last reply
                                      0
                                      • D Offline
                                        D Offline
                                        Dii
                                        wrote on last edited by
                                        #90

                                        Don't bother with the log files, I guess Qt looks at the wrong place for the socket file...

                                        Let's check this line in your mysql config file (my.cnf):

                                        socket = /var/run/mysqld/mysqld.sock

                                        You should find my.cnf in /etc/ or /etc/mysql/ ... I don't know ubuntu that much.

                                        1 Reply Last reply
                                        0
                                        • D Offline
                                          D Offline
                                          doforumda
                                          wrote on last edited by
                                          #91

                                          1st solution returns this
                                          @
                                          root@zafar-laptop:/# find /opt/lampp -name *.log
                                          /opt/lampp/htdocs/xampp/contrib/sqlnet.log
                                          @

                                          1 Reply Last reply
                                          0

                                          • Login

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