Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. International
  3. Italian
  4. Problema con query e QSqlQuery prepare
Forum Updated to NodeBB v4.3 + New Features

Problema con query e QSqlQuery prepare

Scheduled Pinned Locked Moved Solved Italian
23 Posts 2 Posters 8.3k 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.
  • F fermatqt

    ok, allora:

    1. ho messo così, me in output non dice nulla; quindi la query dovrebbe essere eseguita:
            if (db->isOpened()) {
                QFile queryFile(":/get_listini_articolo.txt");
                queryFile.open(QFile::ReadOnly | QFile::Text);
                QString strQuery = QTextStream(&queryFile).readAll();
                strQuery.replace("\n", "");
                QSqlQuery query;
                query.prepare(strQuery);
                query.bindValue(":articol", "C165-000");
                //query.exec();
                if(!query.exec()) Q_ASSERT(false);
    
                /*QMapIterator<QString, QVariant> i(query.boundValues());
                while (i.hasNext()) {
                    i.next();
                    qDebug() << i.key().toUtf8().data() << ": " << i.value().toString().toUtf8().data() << endl;
                }
                qDebug() << query.lastError().text();*/
    
                int rows = 0;
                while (query.next()) {
                    ui->tblArticoli->insertRow(ui->tblArticoli->rowCount());
                    for (int i = 0; i < header.size(); ++i) {
                        ui->tblArticoli->setItem(rows, i, new QTableWidgetItem(query.value(header.at(i)).toString()));
                    }
                    rows++;
                }
                query.clear();
            }
    
    1. MA.CODINT è un VARCHAR; il db è ORACLE

    2. se esguo la query su SQLDEVELOPER funziona correttamente; anzi, io le faccio sempre prima su SQLDEVELOPER in modo da scrivere query corrette ed evitare questi problemi; ed infatti è questo che mi lascia perplesso!

    VRoninV Offline
    VRoninV Offline
    VRonin
    wrote on last edited by
    #21

    @fermatqt said in Problema con query e QSqlQuery prepare:

    MA.CODINT è un VARCHAR

    Mi hai mentito! :)

    quindi SELECT TRIM(CODINT) tc FROM MAT_ANAG WHERE tc = ? dovrebbe funzionare

    "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
    ~Napoleon Bonaparte

    On a crusade to banish setIndexWidget() from the holy land of Qt

    1 Reply Last reply
    0
    • F Offline
      F Offline
      fermatqt
      wrote on last edited by
      #22

      scusa ero sicuro che fosse un VARCHAR!!
      ma più che altro su mysql non mi sembra di riscontrare questo comportamento che ho su oracle (ma magari mi sbaglio).

      cmq col TRIM funziona.

      grazie mille, ti devo una bottiglia di vodka!!

      1 Reply Last reply
      0
      • VRoninV Offline
        VRoninV Offline
        VRonin
        wrote on last edited by
        #23

        Nessun problem, felice che si sia risolto

        "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
        ~Napoleon Bonaparte

        On a crusade to banish setIndexWidget() from the holy land of Qt

        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