青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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 米米 閱讀(551) 評論(0)  編輯 收藏 引用 所屬分類: qt
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品在线电影| 欧美日韩国产精品一区| 亚洲一区久久久| 久久亚洲私人国产精品va| 亚洲欧美激情视频在线观看一区二区三区| 久久精品综合| 久久精品视频在线播放| 国产精品久久9| 亚洲美女在线视频| 亚洲精品国久久99热| 欧美专区日韩专区| 午夜国产不卡在线观看视频| 欧美日韩四区| 一区二区三区久久网| 亚洲片区在线| 男男成人高潮片免费网站| 久久亚洲综合色| 国产一区二区三区观看| 欧美一级久久| 久久久国产精品一区| 国产欧美一区在线| 亚洲欧美日韩一区二区三区在线观看 | 久久久久久自在自线| 一本色道婷婷久久欧美| 久久亚洲综合色| 巨胸喷奶水www久久久免费动漫| 国产精品一区三区| 亚洲免费在线| 久久久视频精品| 韩国一区二区三区美女美女秀| 亚洲欧美亚洲| 久久影视三级福利片| 狠狠色丁香婷婷综合| 欧美一区二区三区免费观看| 亚洲欧美伊人| 国产一区二区三区高清播放| 久久国产精品久久w女人spa| 久久嫩草精品久久久精品| 国产一区二区精品丝袜| 久久久综合激的五月天| 亚洲国产精品久久久| 亚洲人www| 欧美日韩中文字幕精品| 亚洲特级片在线| 欧美中文字幕在线观看| 在线播放一区| 欧美另类在线播放| 亚洲一区二区精品| 毛片一区二区| 中文日韩电影网站| 国产日本欧洲亚洲| 美女精品网站| av成人免费在线| 久久久不卡网国产精品一区| 亚洲激情社区| 欧美午夜久久| 久久久天天操| 9l视频自拍蝌蚪9l视频成人| 久久久99久久精品女同性| 亚洲国产aⅴ天堂久久| 国产精品99一区| 卡通动漫国产精品| 一区二区三区欧美| 蜜臀久久99精品久久久久久9| aa国产精品| 国产真实久久| 国产精品都在这里| 久久一区中文字幕| 亚洲欧美日韩在线观看a三区| 欧美国产视频在线| 久久国产精品久久精品国产| 亚洲黑丝一区二区| 国产婷婷精品| 国产精品久久久久999| 久久夜色撩人精品| 亚洲男人第一网站| 亚洲美女黄网| 欧美成人一区二区三区在线观看| 亚洲素人一区二区| 亚洲国产精品日韩| 国产日韩欧美综合一区| 欧美日韩综合视频| 欧美国产先锋| 久久综合九色| 久久久久成人精品免费播放动漫| 一本色道久久综合亚洲精品不| 欧美xxx在线观看| 久久久久久久高潮| 欧美在线观看视频一区二区三区| 99成人在线| 亚洲欧洲精品成人久久奇米网 | 免费一级欧美片在线播放| 亚洲在线一区二区| 一本色道久久综合亚洲精品小说 | 韩国精品主播一区二区在线观看| 欧美午夜宅男影院在线观看| 欧美大色视频| 美女网站久久| 鲁大师成人一区二区三区| 欧美在线视频网站| 性欧美xxxx大乳国产app| 亚洲午夜精品网| 国产精品99久久久久久久久久久久| 亚洲国产精品一区二区www| 免费亚洲网站| 欧美激情第9页| 亚洲第一主播视频| 亚洲国产清纯| 亚洲经典一区| 亚洲精品一区二区三区福利| 亚洲毛片在线看| 日韩一区二区免费高清| 艳女tv在线观看国产一区| 一区二区三区偷拍| 亚洲特色特黄| 欧美在线视频观看| 久久全国免费视频| 免费成年人欧美视频| 欧美国产一区在线| 欧美日韩国产影院| 国产精品你懂得| 国产美女精品视频免费观看| 国产综合色产在线精品| 在线免费精品视频| 亚洲精品一区久久久久久| 99精品欧美一区| 亚洲欧美激情四射在线日 | 久久九九久精品国产免费直播| 久久久亚洲高清| 欧美国产日产韩国视频| 亚洲国产婷婷| 亚洲视频一区| 久久精品国产欧美激情| 欧美大色视频| 国产精品久久久亚洲一区| 国产一区在线免费观看| 亚洲国产视频直播| 亚洲免费在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲全黄一级网站| 亚洲欧美大片| 欧美大片在线看免费观看| 国产精品久久久久久久久久尿 | 香蕉成人久久| 男同欧美伦乱| 欧美小视频在线| 在线播放亚洲| 亚洲欧美乱综合| 欧美激情视频网站| 亚洲资源在线观看| 牛人盗摄一区二区三区视频| 国产精品久久久久久久久果冻传媒| 国内精品久久久久久久97牛牛| 亚洲日本在线观看| 久久精品国产999大香线蕉| 亚洲高清一区二| 久久精品国产综合精品| 欧美日韩中文字幕日韩欧美| 在线电影国产精品| 欧美怡红院视频| 亚洲精品国产无天堂网2021| 久久精品国产v日韩v亚洲| 欧美三级在线| 亚洲精品社区| 免费精品视频| 午夜天堂精品久久久久| 欧美日韩视频专区在线播放 | 欧美视频在线一区| 亚洲精品国产精品久久清纯直播| 久久精品理论片| 亚洲一区二区精品| 欧美日韩亚洲一区在线观看| 亚洲激情啪啪| 蜜臀久久久99精品久久久久久| 午夜精品国产更新| 国产精品卡一卡二卡三| 一区二区电影免费观看| 亚洲黄色高清| 久久亚洲国产精品一区二区 | 亚洲欧美亚洲| 99在线热播精品免费| 欧美精品激情在线| 亚洲韩国青草视频| 欧美大片在线观看一区| 久久久无码精品亚洲日韩按摩| 国产小视频国产精品| 欧美一区综合| 性欧美办公室18xxxxhd| 国产无一区二区| 久久精品国产欧美亚洲人人爽| 亚洲小视频在线| 国产精品毛片大码女人| 亚洲欧美一区二区在线观看| 99精品视频一区| 国产精品国产自产拍高清av王其| 亚洲一区国产| 亚洲女人天堂成人av在线| 国产精品老牛| 久久er99精品| 久久国产精品99国产|