venerdì 25 gennaio 2013

SQLite in Qt

In questo post verra' presentato un esempio di utilizzo di Qt con Sqlite

Le librerie Qr hanno gia' al loro interno il supporto per Sqlite per cui non e' necessaria l'installazione di nessun componente aggiuntivo
Per prima cosa si deve modificare il file .pro per includere il supporto sql (come evidenziato in giallo nel listato sottostante)



sql.pro
--------------------------------------------

QT       += core
QT       += sql
QT       -= gui

TARGET = sql
CONFIG   += console
CONFIG   -= app_bundle

TEMPLATE = app


SOURCES += main.cpp

--------------------------------------------

L'esempio effettua tre query
Nella prima viene creata una tabella inserendo tre righe
Nella seconda viene effettuata una SELECT senza vincoli
Nella terza viene effettuata una SELECT condizionata da un WHERE
Il codice e' sostanzialmente autoesplicativo.L'unica cosa da sottolineare e' che in QtCreator sotto Windows si dove dichiarare un include <QtSql> mentre in Linux deve essere modificato in <QtSql\QtSql>

main.cpp
--------------------------------------------

#include <QtCore/QCoreApplication>
#include <Qtsql>
//per Linux si deve sostituire la riga precedente con
//#include <QtSql/QtSql>

#include <QDebug>

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

    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
        db.setDatabaseName("c:/punteggio.db");
        if (!db.open()) {

            return false;
        }

        QSqlQuery query;

        query.exec("create table punteggio (id int primary key, "
                                         "nome varchar(20), "
                                         "punti int)");

        query.exec("insert into punteggio values(0, 'Luca', 2)");
        query.exec("insert into punteggio values(1, 'Federico', 102)");
        query.exec("insert into punteggio values(2, 'Alessio', 15)");


        QSqlQuery query2;
        query2.prepare( "SELECT * FROM punteggio" );
        if( !query2.exec() )
        {
            qDebug() << "Errore sulla query";

        }
        while( query2.next() )
        {
            int punti = query2.value(2).toInt();
            QString nome = query2.value(1).toString();
            qDebug() << nome << " " << punti << endl;
        }

        // SELECT CONDIZIONATA DA WHERE
        QSqlQuery query3;
        query3.prepare( "SELECT * FROM punteggio WHERE punti > ?" );
        query3.bindValue(":punti",20);

        if( !query3.exec() )
        {
            qDebug() << "Errore sulla query";

        }
        while( query3.next() )
        {
            int punti = query3.value(2).toInt();
            QString nome = query3.value(1).toString();
            qDebug() << nome << " " << punti << endl;
        }


    return a.exec();
}


--------------------------------------------

asd