首先我的Qtableview中的的內容是從數據庫中查找出來再顯示 出來的。下面是以個關於某個公司信息種類的數據。這是數據庫中的記錄
效果是這樣的:
點擊上面的某行數據,下面的lineEdit中就會顯示出來對應的數據。如下圖所示
再點擊第二條數據,也會顯示出來。
效果很不錯,完美的實現了,自己非常的高興,將過程寫出來,對於初學者而言,可以參考參考。高手請路過
首先,我想到是必須建立信號和槽的連接,只有這樣才能實現實時的顯示,到底需要哪個信號呢?既然是鼠標的單擊,那肯定就是click信號了。
- <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的點擊信號,和自己寫的槽函數進行關聯。
下面是自己寫的槽函數:
- <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>
<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() 就是對應數據表中的某個列的屬性,必須和自己數據表中的列對應,否則顯示的內容對應不上,這點一點要注意。