C/C++ Qt数据库SqlRelationalTable关联表怎么使用
发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,本篇内容介绍了"C/C++ Qt数据库SqlRelationalTable关联表怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧
千家信息网最后更新 2025年11月10日C/C++ Qt数据库SqlRelationalTable关联表怎么使用
本篇内容介绍了"C/C++ Qt数据库SqlRelationalTable关联表怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
首先我们创建两张表,一张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/lysharkMainWindow::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;}最终绑定效果如下图:

"C/C++ Qt数据库SqlRelationalTable关联表怎么使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
数据
数据表
关联
学院
数据库
代码
内容
字段
学生
更多
知识
存储
实用
学有所成
接下来
函数
名字
名称
困境
姓名
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
手机视频无线服务器有用吗
江苏创新网络技术服务哪家好
数据库按某字段升序
修改数据库多个数据
停车场收费管理数据库
孝感软件开发定制
3241在数据库中啥意思
plant3d导入数据库
广东服务器电源怎么样
维护服务器安全的方法
mc1.7.2服务器
服务器负载低什么意思
连接数据库无服务器
网络安全包保管理办法
数据库时间戳 同步
阳江软件开发就业
中国软件开发的什么软件
java 文件下载服务器
方舟服务器回收
中国核心期刊数据库收录期刊
小学教师网络安全教育事迹
天津融和互联网络科技
软件开发项目经理岗位描述
1.网络安全的定义
湖北电信dns服务器
甘肃省2021网络安全宣传周
楚汉互联网科技
浙江广东网络安全培训攻防技术
网络安全申论大作文
政府网络安全 存在问题