將Qtableview中的數據顯示在相應的控件上

學習Qt有一段時間了,幾天做東西需要將Qtableview中的數據顯示在相應的控件上,想看好久,終於搞定了,特意拿出來,和大家分享,也當做是自己的一個學習筆記。

    首先我的Qtableview中的的內容是從數據庫中查找出來再顯示 出來的。下面是以個關於某個公司信息種類的數據。這是數據庫中的記錄

    效果是這樣的:

   

點擊上面的某行數據,下面的lineEdit中就會顯示出來對應的數據。如下圖所示

再點擊第二條數據,也會顯示出來。


效果很不錯,完美的實現了,自己非常的高興,將過程寫出來,對於初學者而言,可以參考參考。高手請路過

首先,我想到是必須建立信號和槽的連接,只有這樣才能實現實時的顯示,到底需要哪個信號呢?既然是鼠標的單擊,那肯定就是click信號了。

  1. <span style="font-family:KaiTi_GB2312;font-size:18px;"> connect(ui->Supplier_tableView,SIGNAL(clicked(QModelIndex)),this,SLOT(ShowSupplyclick()));</span>  
<span style="font-family:KaiTi_GB2312;font-size:18px;"> connect(ui->Supplier_tableView,SIGNAL(clicked(QModelIndex)),this,SLOT(ShowSupplyclick()));</span>
將界面中的Qtableview的點擊信號,和自己寫的槽函數進行關聯

下面是自己寫的槽函數


  1. <span style="font-family:KaiTi_GB2312;font-size:18px;">/* 
  2.  *獲取當前鼠標點擊的數據表中的內容,並將其顯示在相應的控件上 
  3. */  
  4. void Basic_Data_Dialog::ShowSupplyclick()  
  5. {  
  6.     static QSqlQueryModel supplymodel(ui->Supplier_tableView);  
  7.     supplymodel.setQuery(QString("select * from Supply;"));  
  8.     int row = ui->Supplier_tableView->currentIndex().row();  
  9.     QSqlRecord record = supplymodel.record(row);  
  10.     ui->EditsupId->setText(record.value(0).toString());  
  11.     ui->EditSupName->setText(record.value(1).toString());  
  12.     ui->EditSupAdress->setText(record.value(2).toString());  
  13.     ui->EditSupPhon->setText(record.value(3).toString());  
  14.     ui->EditSupMail->setText(record.value(4).toString());  
  15.     ui->EditSupRemark->setText(record.value(5).toString());  
  16. }</span>  
<span style="font-family:KaiTi_GB2312;font-size:18px;">/*
 *獲取當前鼠標點擊的數據表中的內容,並將其顯示在相應的控件上
*/
void Basic_Data_Dialog::ShowSupplyclick()
{
    static QSqlQueryModel supplymodel(ui->Supplier_tableView);
    supplymodel.setQuery(QString("select * from Supply;"));
    int row = ui->Supplier_tableView->currentIndex().row();
    QSqlRecord record = supplymodel.record(row);
    ui->EditsupId->setText(record.value(0).toString());
    ui->EditSupName->setText(record.value(1).toString());
    ui->EditSupAdress->setText(record.value(2).toString());
    ui->EditSupPhon->setText(record.value(3).toString());
    ui->EditSupMail->setText(record.value(4).toString());
    ui->EditSupRemark->setText(record.value(5).toString());
}</span>

    代碼中寫的很詳細了,就不用過多的介紹了。上面的  record.value(0).toString() 就是對應數據表中的某個列的屬性,必須和自己數據表中的列對應,否則顯示的內容對應不上,這點一點要注意。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章