C/C++ Qt数据库SqlRelationalTable关联表怎么使用
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本篇内容介绍了"C/C++ Qt数据库SqlRelationalTable关联表怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧
千家信息网最后更新 2025年01月19日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安全错误
数据库的锁怎样保障安全
承德商城分销软件开发多少钱
原神为什么会出现无法连接服务器
欧盟数据库开放
无隐私网络安全吗
哪部分是网络安全的中心
安卓9100打印服务器
数据库如何添加数据库文件
网络安全需要核心技术例子
we8数据库
网络技术基础的书
天龙八部所有服务器都可以用吗
亚马逊服务器性能
联合目录是不是书目数据库
市场监管局强化网络安全工作
因数据库属于回避恢复
山东pdu服务器电源厂商
互联网科技有限公司造车
魔域数据库
应用软件开发工资怎么样
2019联通网络技术
fifa球员数据库巴萨
梳理网络安全情报的软件
普陀区合格软件开发服务保障
服务器硬盘不识别怎么回事
网络安全知识 百度文库
数据库中如何删除重复信息
互联网科技公司服务宣传语
违反网络安全法已备案
建筑通讯与网络技术 教材
r920服务器