• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會(huì)很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::

            #include <qDebug>

            #include "dbutil/DBUtil.h"

            #include <QtSql>


            bool insert1();

            bool insert2();


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

                QSqlDatabase db = DBUtil::getDatabase();

                qDebug() << db.driver()->hasFeature(QSqlDriver::Transactions); // 查看數(shù)據(jù)庫(kù)是否支持事務(wù)處理.

                db.transaction();

                qDebug() << "Begin transaction";


                bool ok1 = insert1();

                bool ok2 = insert2();


                if (ok1 && ok2) {

                    db.commit();

                    qDebug() << "Commit";

                } else {

                    db.rollback();

                    qDebug() << "Rollback";

                }

            }


            bool insert1() {

                QSqlDatabase db1 = DBUtil::getDatabase();

                QString sql1("INSERT INTO a(id) VALUES(1)");

                QSqlQuery query1(db1);


                bool ok1 = true;

                ok1 = query1.exec(sql1);


                if (!ok1) {

                    qDebug() << QString("Query1: %1").arg(query1.lastError().text());

                }


                return ok1;

            }


            bool insert2() {

                QSqlDatabase db2 = DBUtil::getDatabase();

                QString sql2("INSERT INTO b(amount2) VALUES(30)");

                QSqlQuery query2(db2);


                bool ok2 = true;

                ok2 = query2.exec(sql2);


                if (!ok2) {

                    qDebug() << QString("Query2: %1").arg(query2.lastError().text());

                }


                return ok2;

            }


            Qt中事務(wù)的提交, 如果在一串操作之后, 其中有失敗也有成功的, 但是在調(diào)用db.commit(), 那么所有正確的操作都會(huì)更新數(shù)據(jù)庫(kù), 而失敗的操作仍然失敗. 所以得自己手動(dòng)的使用db.rollback(), 如下面的片段:

            bool ok1, ok2;

            QString error1, error2;


            QString sql1 = "insert into a(id) values(3)";

            QString sql2 = "insert into b(amount2) values(100)";


            QSqlDatabase db = DBUtil::getDatabase();

            db.transaction();


            QSqlQuery query1(db);

            ok1 = query1.exec(sql1);


            QSqlQuery query2(db);

            ok2 = query2.exec(sql2);


            db.commit();

            因?yàn)閝uery2操作失敗, 但是query1的操作成功, 而后面使用了db.commit(), 所以query1的操作提交了, 但是query2的操作沒(méi)有更新數(shù)據(jù)庫(kù). 


            如果開(kāi)啟了事務(wù), 在數(shù)據(jù)庫(kù)操作之后, 沒(méi)有手動(dòng)的調(diào)用db.commit(), 那么操作也不會(huì)提交.

             

            posted on 2009-07-24 12:09 逛奔的蝸牛 閱讀(1765) 評(píng)論(1)  編輯 收藏 引用 所屬分類(lèi): Qt

            評(píng)論

            # re: Qt: 事務(wù)處理片斷 2009-07-24 12:12 暗金裝備
            QSqlDatabase DBUtil::getDatabase(bool *ok, QString *error) {
            QSqlDatabase db;

            if (!QSqlDatabase::contains(DBUtil::DATABASE_CONNECT_NAME)) {
            db = QSqlDatabase::addDatabase("QSQLITE", DBUtil::DATABASE_CONNECT_NAME);
            db.setDatabaseName(ConfigUtil::getInstance().getDatabasePath());
            //qDebug() << "與數(shù)據(jù)庫(kù)建立連接";
            } else {
            db = QSqlDatabase::database(DBUtil::DATABASE_CONNECT_NAME, true);
            }

            if (!db.isOpen()) {
            bool result = db.open();

            if (0 != ok) {
            *ok = result;
            }
            if ((false == result) && (0 != error)) {
            *error = db.lastError().text();
            }
            }

            return db;
            }  回復(fù)  更多評(píng)論
              

            久久免费99精品国产自在现线 | 区亚洲欧美一级久久精品亚洲精品成人网久久久久| 一本一本久久A久久综合精品| 久久久久青草线蕉综合超碰| 久久综合亚洲欧美成人| 久久久一本精品99久久精品66| 国产成人精品久久免费动漫| 久久精品国产亚洲AV不卡| 蜜桃麻豆WWW久久囤产精品| 久久99热狠狠色精品一区| 午夜精品久久久久久| 国产精品美女久久久| 区久久AAA片69亚洲| 91久久精品无码一区二区毛片| 久久精品国产亚洲AV影院| 日韩亚洲欧美久久久www综合网| 综合久久精品色| 久久久久无码国产精品不卡| 无码久久精品国产亚洲Av影片| 久久久不卡国产精品一区二区| 久久久久久亚洲AV无码专区| 久久午夜免费视频| 热久久最新网站获取| 亚洲精品高清国产一线久久| 91精品国产综合久久精品| 国产亚洲精品美女久久久| 久久影视国产亚洲| 国产亚洲精午夜久久久久久| 色8久久人人97超碰香蕉987| 久久只有这精品99| 久久人人爽人人爽人人av东京热| 久久国产高清一区二区三区| 亚洲精品高清久久| 99久久精品费精品国产| 9久久9久久精品| 人人狠狠综合久久亚洲88| 久久综合九色综合97_久久久| 国产精品无码久久综合| 久久伊人精品青青草原高清| 天天久久狠狠色综合| 国产精品热久久毛片|