• <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>
            posts - 10,  comments - 2,  trackbacks - 0

            如有改動(dòng)以CSDN版為主,格式比較好看
            http://blog.csdn.net/reborntercel/article/details/7000220


                QSqlQueryModel類為SQL的結(jié)果集提供了一個(gè)只讀的數(shù)據(jù)模型,下面我們先利用這個(gè)類進(jìn)行一個(gè)最簡(jiǎn)單的操作.

            常用函數(shù)

            void QSqlQueryModel::setQuery ("SQL語句") // 執(zhí)行SQL語句,此處還可以傳入QSqlQuery對(duì)象,此時(shí)可以利用QSqlQuery類的某些特性,如預(yù)操作等.

            setHeaderData()     //設(shè)置水平頭標(biāo)題

            columnCount(); //獲得列數(shù)

            columnCount(); //獲得列數(shù)

            QSqlRecord QSqlQueryModel::record ( int row ) const //返回row行包含的信息,可訪問單條的記錄

            QModelIndex QAbstractItemModel::index ( int row, int column, const QModelIndex & parent = QModelIndex() )  //返回指定的行和列的索引(index)

            index.data()  //返回index索引的值

            query() //返回與QSqlQuery相關(guān)的模型

            1. QSqlQueryModel *model = new QSqlQueryModel;  
            2. model->setQuery(“select * from student”);  
            3. model->setHeaderData(0, Qt::Horizontal, tr(“id”));  
            4. model->setHeaderData(1, Qt::Horizontal, tr(“name”));  
            5. QTableView *view = new QTableView;  
            6. view->setModel(model);  
            7. view->show();  

             

            利用query執(zhí)行SQL語句

            1. QSqlQuery query = model->query();  
            2. query.exec("select name from student where id = 1");  
            3. query.next();  
            4. qDebug() << query.value(0).toString(); // 如果上面的select改成insert語句,而且是顯示在QTableView中的話,需再查詢一次model->setQuery("select ...")才能顯示剛插入的語句  


                   因?yàn)镼SqlQueryMode模型默認(rèn)是只讀的,所以我們?cè)诖翱谏喜⒉荒軐?duì)表格中的內(nèi)容進(jìn)行修改。但是我們可以創(chuàng)建自己的模型,然后按照我們自己的需要來顯示數(shù)據(jù)和修改數(shù)據(jù)。如果要想使其可讀寫,需要自己的類繼承自QSqlQueryModel,并且重寫setData() 和 flags() 兩個(gè)函數(shù)如果我們要改變數(shù)據(jù)的顯示,就要重寫data() 函數(shù)

            1. Qt::ItemFlags MySqlQueryModel::flags(const QModelIndex &index) const //返回表格是否可更改的標(biāo)志   
            2. {  
            3.      Qt::ItemFlags flags = QSqlQueryModel::flags(index);  
            4.      if (index.column() == 1) //第二個(gè)字段可更改,即學(xué)生的名字字段   
            5.         flags |= Qt::ItemIsEditable;  
            6.      return flags;  
            7.  }  
            8.   
            9. bool MySqlQueryModel::setData(const QModelIndex &index, const QVariant &value, int /* role *///表格添加數(shù)據(jù)   
            10. {  
            11.     QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);  
            12.     int id = data(primaryKeyIndex).toInt(); //獲取id號(hào) 也可以這樣用,primaryKeyIndex.data();   
            13.   
            14.     clear();  
            15.     bool isOk;  
            16.     if (index.column() == 1) //第二個(gè)屬性可更改   
            17.     {  
            18.         QSqlQuery query;  
            19.         query.prepare("UPDATE STUDENT SET NAME = :name WHERE id = :id");  
            20.         query.bindValue(":name","小五");  
            21.         query.bindValue(":id",id);  
            22.         isOk = query.exec();  
            23.   
            24.         refresh();// 此處最好添加代碼刷新結(jié)果,或在此調(diào)用刷新函數(shù)   
            25.         return isOK;  
            26.     }  
            27.     return false;  
            28. }  
            29.   
            30. void MySqlQueryModel::refresh() //更新顯示   
            31. {  
            32.     setQuery("select * from student");  
            33.     setHeaderData(0, Qt::Horizontal, QObject::tr("學(xué)號(hào)ID"));  
            34.     setHeaderData(1, Qt::Horizontal, QObject::tr("名字"));  
            35. }  
            36.   
            37. // tata()改寫某一個(gè)列的顯示方式   
            38. QVariant MySqlQueryModel::data(const QModelIndex &index, int role) const  
            39.          //更改數(shù)據(jù)顯示樣式   
            40. {  
            41.     QVariant value = QSqlQueryModel::data(index, role);  
            42.     if (role == Qt::TextColorRole && index.column() == 0)  
            43.         return qVariantFromValue(QColor(Qt::red)); //第一個(gè)屬性的字體顏色為紅色   
            44.     return value;  
            45. }  
            posted on 2011-11-22 15:16 再生的雄鷹 閱讀(2937) 評(píng)論(0)  編輯 收藏 引用

            <2011年11月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            常用鏈接

            留言簿(1)

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            亚洲精品无码成人片久久| 91亚洲国产成人久久精品网址| 91精品日韩人妻无码久久不卡 | 久久无码专区国产精品发布| 色婷婷狠狠久久综合五月| 久久亚洲中文字幕精品一区| 久久精品国产清高在天天线| 岛国搬运www久久| 亚洲va久久久噜噜噜久久男同| 97久久精品人妻人人搡人人玩 | 伊人久久成人成综合网222| 久久亚洲日韩看片无码| 国产精品丝袜久久久久久不卡| 亚洲国产精品成人久久蜜臀| 国产午夜福利精品久久2021| 久久亚洲精品无码播放| 99久久99这里只有免费费精品| 久久久久久久国产免费看| 久久夜色精品国产噜噜噜亚洲AV| 久久黄视频| 精品999久久久久久中文字幕 | 国产精品免费久久久久影院| 97精品依人久久久大香线蕉97| 国产精品成人99久久久久| 国产精品女同久久久久电影院 | 91精品国产综合久久婷婷| 2021久久精品免费观看| 精品国产热久久久福利| 91久久婷婷国产综合精品青草| 久久亚洲AV成人无码| 天堂无码久久综合东京热| 91精品国产色综久久| 91精品国产色综合久久| 精品少妇人妻av无码久久| 亚洲va中文字幕无码久久| 久久精品国产2020| 久久精品国产亚洲AV忘忧草18| 久久夜色精品国产噜噜亚洲a| 久久久久九九精品影院| 久久精品无码专区免费| 国产激情久久久久影院老熟女免费|