網(wǎng)站首頁 編程語言 正文
C/C++?Qt數(shù)據(jù)庫SqlRelationalTable關(guān)聯(lián)表詳解_C 語言
作者:LyShark ? 更新時(shí)間: 2021-12-02 編程語言在上一篇博文中詳細(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
表存儲(chǔ)學(xué)生名字以及學(xué)生課程號(hào),另一張Departments
存儲(chǔ)每個(gè)編號(hào)所對(duì)應(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é)號(hào)"); 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; }
最終綁定效果如下圖:
原文鏈接:https://www.cnblogs.com/LyShark/p/15668393.html
相關(guān)推薦
- 2022-09-12 Shell編程之/bin/bash和/bin/sh的區(qū)別淺析_linux shell
- 2022-12-25 一文帶你了解Go語言中的指針和結(jié)構(gòu)體_Golang
- 2023-04-08 C++對(duì)string進(jìn)行大小寫轉(zhuǎn)換操作方法_C 語言
- 2022-09-12 nginx訪問報(bào)403錯(cuò)誤的幾種情況詳解_nginx
- 2022-09-30 Qt編寫秒表功能_C 語言
- 2022-06-22 在?Python?中利用Pool?進(jìn)行多處理_python
- 2022-04-16 ASP.NET?Core命令行界面CLI用法_基礎(chǔ)應(yīng)用
- 2023-12-18 IllegalArgumentException異常產(chǎn)生原因及解決方案
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支