在上一篇博文中詳細介紹了SqlTableModle組件是如何使用的,本篇博文將介紹SqlRelationalTable關聯表組件,該組件其實是SqlTableModle組件的擴展類,SqlRelationalTable組件可以關聯某個主表中的外鍵,例如將主表中的某個欄位與附加表中的特定欄位相關聯起來,QSqlRelation(關聯表名,關聯ID,名稱)就是用來實作多表之間快速關聯的,
首先我們創建兩張表,一張Student表存盤學生名字以及學生課程號,另一張Departments存盤每個編號所對應的系所名稱,運行代碼完成創建,
void MainWindow::InitSQL()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("./lyshark.db");
if (!db.open())
return;
// 執行SQL創建表
db.exec("DROP TABLE Student");
db.exec("CREATE TABLE Student ("
"id INTEGER PRIMARY KEY AUTOINCREMENT, "
"name VARCHAR(40) NOT NULL, "
"departID INTEGER NOT NULL)"
);
// 逐條插入資料
db.exec("INSERT INTO Student(name,departID) VALUES('zhangsan',10)");
db.exec("INSERT INTO Student(name,departID) VALUES('lisi',20)");
db.exec("INSERT INTO Student(name,departID) VALUES('wangwu',30)");
db.exec("INSERT INTO Student(name,departID) VALUES('wangmazi',40)");
db.exec("DROP TABLE Departments");
db.exec("CREATE TABLE Departments("
"departID INTEGER NOT NULL,"
"department VARCHAR(40) NOT NULL)"
);
db.exec("INSERT INTO Departments(departID,department) VALUES (10,'數學學院')");
db.exec("INSERT INTO Departments(departID,department) VALUES (20,'物理學院')");
db.exec("INSERT INTO Departments(departID,department) VALUES (30,'計算機學院')");
db.commit();
db.close();
}
初始化后將得到兩張資料表,這兩張表通過departID相關聯,如下:

創建完成后,我們在程式的建構式直接實作系結即可,這段代碼很簡單如下:
// https://www.cnblogs.com/lyshark
MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
ui->setupUi(this);
InitSQL();
// 打開資料庫
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("./lyshark.db");
if (!db.open())
return;
this->setCentralWidget(ui->tableView);
ui->tableView->setSelectionBehavior(QAbstractItemView::SelectItems);
ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection);
ui->tableView->setAlternatingRowColors(true);
// 打開資料表
tabModel=new QSqlRelationalTableModel(this,DB);
tabModel->setTable("Student"); // 設定資料表
tabModel->setEditStrategy(QSqlTableModel::OnManualSubmit); // OnManualSubmit
tabModel->setSort(0,Qt::AscendingOrder);
tabModel->setHeaderData(0,Qt::Horizontal,"學號");
tabModel->setHeaderData(1,Qt::Horizontal,"姓名");
tabModel->setHeaderData(2,Qt::Horizontal,"學院");
// 設定代碼欄位的查詢關系資料表
// 打開Departments表,關聯ID和department
tabModel->setRelation(2,QSqlRelation("Departments","departID","department"));
theSelection=new QItemSelectionModel(tabModel);
ui->tableView->setModel(tabModel);
ui->tableView->setSelectionModel(theSelection);
ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->tableView)); // 為關系型欄位設定預設代理組件
tabModel->select(); // 打開資料表
}
MainWindow::~MainWindow()
{
delete ui;
}
最終系結效果如下圖:

著作權宣告: 本博客文章與代碼均為學習時整理的筆記,博客中除去明確標注有參考文獻的文章,其他文章 [均為原創] 作品,轉載請 [添加出處] ,您添加出處是我創作的動力!
本博客所有文章除參考文獻特別宣告外,均采用 知識共享 署名-非商業性使用 [CC BY-NC-ND 4.0] 國際許可協議,請遵循協議許可
警告:如果您惡意轉載本人文章并被本人發現,則您的整站文章,將會變為我的原創作品,請相互尊重 !
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/378085.html
標籤:C++
上一篇:【1】Embarrassingly Parallel(易并行計算問題)
下一篇:LeetCode:有效的數獨
