C/C++?Qt數(shù)據(jù)庫SqlRelationalTable關(guān)聯(lián)表詳解
在上一篇博文中詳細(xì)介紹了SqlTableModle組件是如何使用的,本篇博文將介紹SqlRelationalTable
關(guān)聯(lián)表組件,該組件其實(shí)是SqlTableModle
組件的擴(kuò)展類,SqlRelationalTable
組件可以關(guān)聯(lián)某個(gè)主表中的外鍵,例如將主表中的某個(gè)字段與附加表中的特定字段相關(guān)聯(lián)起來,QSqlRelation(關(guān)聯(lián)表名,關(guān)聯(lián)ID,名稱)
就是用來實(shí)現(xiàn)多表之間快速關(guān)聯(lián)的。
首先我們創(chuàng)建兩張表,一張Student
表存儲學(xué)生名字以及學(xué)生課程號,另一張Departments
存儲每個(gè)編號所對應(yīng)的系所名稱,運(yùn)行代碼完成創(chuàng)建。
void MainWindow::InitSQL() { QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("./lyshark.db"); if (!db.open()) return; // 執(zhí)行SQL創(chuàng)建表 db.exec("DROP TABLE Student"); db.exec("CREATE TABLE Student (" "id INTEGER PRIMARY KEY AUTOINCREMENT, " "name VARCHAR(40) NOT NULL, " "departID INTEGER NOT NULL)" ); // 逐條插入數(shù)據(jù) 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,'數(shù)學(xué)學(xué)院')"); db.exec("INSERT INTO Departments(departID,department) VALUES (20,'物理學(xué)院')"); db.exec("INSERT INTO Departments(departID,department) VALUES (30,'計(jì)算機(jī)學(xué)院')"); db.commit(); db.close(); }
初始化后將得到兩張數(shù)據(jù)表,這兩張表通過departID
相關(guān)聯(lián),如下:
創(chuàng)建完成后,我們在程序的構(gòu)造函數(shù)直接實(shí)現(xiàn)綁定即可,這段代碼很簡單如下:
// https://www.cnblogs.com/lyshark MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); InitSQL(); // 打開數(shù)據(jù)庫 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); // 打開數(shù)據(jù)表 tabModel=new QSqlRelationalTableModel(this,DB); tabModel->setTable("Student"); // 設(shè)置數(shù)據(jù)表 tabModel->setEditStrategy(QSqlTableModel::OnManualSubmit); // OnManualSubmit tabModel->setSort(0,Qt::AscendingOrder); tabModel->setHeaderData(0,Qt::Horizontal,"學(xué)號"); tabModel->setHeaderData(1,Qt::Horizontal,"姓名"); tabModel->setHeaderData(2,Qt::Horizontal,"學(xué)院"); // 設(shè)置代碼字段的查詢關(guān)系數(shù)據(jù)表 // 打開Departments表,關(guān)聯(lián)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)); // 為關(guān)系型字段設(shè)置缺省代理組件 tabModel->select(); // 打開數(shù)據(jù)表 } MainWindow::~MainWindow() { delete ui; }
最終綁定效果如下圖:
到此這篇關(guān)于C/C++ Qt數(shù)據(jù)庫SqlRelationalTable關(guān)聯(lián)表詳解的文章就介紹到這了,更多相關(guān)C++ Qt SqlRelationalTable關(guān)聯(lián)表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言調(diào)用攝像頭實(shí)現(xiàn)生成yuv未壓縮圖片
這篇文章主要為大家詳細(xì)介紹了C語言如何調(diào)用攝像頭實(shí)現(xiàn)生成yuv未壓縮圖片,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以參考一下2023-11-11C++用指針變量作為函數(shù)的參數(shù)接受數(shù)組的值的問題詳細(xì)總結(jié)
以下是對C++中用指針變量作為函數(shù)的參數(shù)接受數(shù)組的值的問題進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10關(guān)于CLion配置visual?studio(msvc)和JOM多核編譯的問題
這篇文章主要介紹了CLion配置visual?studio(msvc)和JOM多核編譯,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07VS2019配置opencv詳細(xì)圖文教程和測試代碼的實(shí)現(xiàn)
這篇文章主要介紹了VS2019配置opencv詳細(xì)圖文教程和測試代碼的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04VsCode安裝和配置c/c++環(huán)境小白教程(圖文)
本文主要介紹了VsCode安裝和配置c/c++環(huán)境小白教程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01C++編譯錯(cuò)誤variable-sized?object?may?not?be?initiali問題
這篇文章主要介紹了C++編譯錯(cuò)誤variable-sized?object?may?not?be?initiali問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05