C/C++ Qt 数据库SqlRelationalTable关联表
2021-12-09 17:32
996 查看
在上一篇博文中详细介绍了
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->setItemD ad8 elegate(new QSqlRelationalDelegate(ui->tableView)); // 为关系型字段设置缺省代理组件 tabModel->select(); // 打开数据表 } MainWindow::~MainWindow() { delete ui; }
最终绑定效果如下图:
相关文章推荐
- Qt/C++ 数据库SQL 增删改查 语句示例
- QT C++ 5.13.2使用QMYSQL driver连接MaraiDB数据库
- Qt/C++ 加载数据库出现qt_sql_default_connection提醒
- Qt5.6.1、c++、sqlite3数据库
- Qt Programing With C++ (2nd) 之 find dialog
- 安装C++ GUI Qt 3 运行程序无法找到qt-mtnc321.dll
- 学习实践:使用模式,原则实现一个C++数据库訪问类
- 数据库 ADO 另一种使用方法和关于C++引用的两个小点【2013.10.16 小记】
- C++专题 - Qt是什么
- UVa 1592 数据库(c++pair)
- C++/Qt 序列化操作
- Qt,一个跨平台的C++应用程序程序开发框架
- c++针对数据库,文件的操作总结(原始)
- 2.关于QT中数据库操作,简单数据库连接操作,数据库的增删改查,QSqlTableModel和QTableView,事务操作,关于QItemDelegate 代理
- 从 相对路径 说开来(从C++到Qt)
- Qt 数据库 结构体和image 数据类型 互转
- Qt C++中的关键字explicit
- 2019面前最新C++开发数据库引擎数据教程
- 关于Qt/C++和QML获取屏幕大小方法的总结
- dev-c++编译连接数据库的项目出现exe应用程序错误