C/C++ Qt数据库SqlRelationalTable关联表怎么使用
发表于:2024-11-27 作者:千家信息网编辑
千家信息网最后更新 2024年11月27日,本篇内容介绍了"C/C++ Qt数据库SqlRelationalTable关联表怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧
千家信息网最后更新 2024年11月27日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安全错误
数据库的锁怎样保障安全
软件开发的SE
建立了一个本地数据库
数据库实验大纲
杭州慧富网络技术
文明上网和网络安全小知识
网络安全队最新消息
数据库 删库
软件开发离职能做什么
綦江应用软件开发
瓦洛兰更新服务器不在线
软件开发工艺流程图
上海工业网络技术厂家现货
大庆餐饮软件开发
联想r525服务器
数据库表分号
软件开发转行做公务员
中兴通讯的网络技术岗位
延长县网络安全宣传活动
三明仁鼎网络技术有限公司
望城软件开发大专学校
群发邮件服务器
2022冬奥会网络安全自查报告
s7-300连接物联网服务器
软件开发3层结构
数据库怎么画出关系
重庆怡讯网络技术有
购进软件开发进项税为多少
平台服务器地址
数据库锁定条件
我的世界手机版生存 服务器