• <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>

            zhonghua

            C++博客 首頁 新隨筆 聯系 聚合 管理
              72 Posts :: 1 Stories :: 4 Comments :: 0 Trackbacks

                QSqlQueryModel類為SQL的結果集提供了一個只讀的數據模型,下面我們先利用這個類進行一個最簡單的操作.

            常用函數

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

            setHeaderData()     //設置水平頭標題

            columnCount(); //獲得列數

            columnCount(); //獲得列數

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

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

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

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

            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執行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 ...")才能顯示剛插入的語句  


                   因為QSqlQueryMode模型默認是只讀的,所以我們在窗口上并不能對表格中的內容進行修改。但是我們可以創建自己的模型,然后按照我們自己的需要來顯示數據和修改數據。如果要想使其可讀寫,需要自己的類繼承自QSqlQueryModel,并且重寫setData() 和 flags() 兩個函數如果我們要改變數據的顯示,就要重寫data() 函數

            1. Qt::ItemFlags MySqlQueryModel::flags(const QModelIndex &index) const //返回表格是否可更改的標志  
            2. {  
            3.      Qt::ItemFlags flags = QSqlQueryModel::flags(index);  
            4.      if (index.column() == 1) //第二個字段可更改,即學生的名字字段  
            5.         flags |= Qt::ItemIsEditable;  
            6.      return flags;  
            7.  }  
            8.   
            9. bool MySqlQueryModel::setData(const QModelIndex &index, const QVariant &value, int /* role */) //表格添加數據  
            10. {  
            11.     QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);  
            12.     int id = data(primaryKeyIndex).toInt(); //獲取id號 也可以這樣用,primaryKeyIndex.data();  
            13.   
            14.     clear();  
            15.     bool isOk;  
            16.     if (index.column() == 1) //第二個屬性可更改  
            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();// 此處最好添加代碼刷新結果,或在此調用刷新函數  
            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("學號ID"));  
            34.     setHeaderData(1, Qt::Horizontal, QObject::tr("名字"));  
            35. //  
            1. //tata()改寫某一個列的顯示樣式,對齊方式  
            2. QVariant MySqlQueryModel::data(const QModelIndex &index, int role) const  
            3. {  
            4.     QVariant value = QSqlQueryModel::data(index, role);  
            5.     if (role == Qt::TextColorRole && index.column() == 0)  
            6.         return qVariantFromValue(QColor(Qt::red)); //第一個屬性的字體顏色為紅色  
            7.   
            8.     if (role == Qt::TextAlignmentRole && index.column() == 1)  
            9.     {  
            10.         value = (Qt::AlignVCenter + Qt::AlignRight); // 靠右垂直居中  
            11.     }  
            12.       
            13.     return value;  

            posted on 2012-04-23 11:21 米米 閱讀(542) 評論(0)  編輯 收藏 引用 所屬分類: qt
            久久香综合精品久久伊人| 久久精品aⅴ无码中文字字幕重口| 久久久精品人妻一区二区三区蜜桃| 久久精品无码午夜福利理论片| jizzjizz国产精品久久| 久久97久久97精品免视看| 色综合久久夜色精品国产| www久久久天天com| 亚洲伊人久久成综合人影院| 人妻精品久久久久中文字幕69 | 亚洲精品国精品久久99热| 亚洲色欲久久久综合网东京热| 国产99精品久久| 久久精品国产亚洲av麻豆图片| 狠狠色丁香婷综合久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 看全色黄大色大片免费久久久| 伊人色综合久久天天人手人婷| 99久久国产综合精品成人影院| 大香伊人久久精品一区二区| 久久精品国产免费| 国产产无码乱码精品久久鸭| 久久亚洲国产成人影院| 日本欧美国产精品第一页久久| 青青草原综合久久| 国内精品久久久久影院免费| 久久精品国产亚洲AV无码娇色| 久久婷婷五月综合国产尤物app | 性做久久久久久免费观看| 国产精品欧美亚洲韩国日本久久| 久久精品亚洲一区二区三区浴池 | 亚洲精品无码久久久久| 亚洲AV伊人久久青青草原| 久久天天日天天操综合伊人av| 日本道色综合久久影院| 久久久青草久久久青草| 波多野结衣中文字幕久久| 97精品久久天干天天天按摩| 久久久久久国产精品无码超碰| 久久精品国产亚洲精品2020| 久久AV高潮AV无码AV|