声明:本文原创于yafeilinux的百度博客,http://hi.baidu.com/yafeilinux转载请注明出处。

讲完QSqlTableModel了,我们这次讲这个类的扩展类QSqlRelationalTableModel,它们没有太大的不同,唯一的就是后者在前者的基础之上添加了外键(或者叫外码)的支持。

QSqlRelationalTableModel,该类为单张的数据库表提供了一个可编辑的数据模型,它支持外键。

我们还是新建Qt4 Gui Application工程,我这里工程名为relationalTableModel ,然后选中QtSql模块,Base class选QWidget。工程建好后,添加C++ Header File ,命名为database.h,更改其内容如下:

#ifndef DATABASE_H

#define DATABASE_H

#include

#include

static bool createConnection()

{

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");

db.setDatabaseName("database.db");

if(!db.open()) return false;

QSqlQuery query;

query.exec("create table student (id int primary key, name vchar,course int)");

query.exec("insert into student values (1,'yafei0',1)");

query.exec("insert into student values (2,'yafei1',1)");

query.exec("insert into student values (3,'yafei2',2)");

query.exec("create table course (id int primary key, name vchar, teacher vchar)");

query.exec("insert into course values (1,'Math','yafeilinux1')");

query.exec("insert into course values (2,'English','yafeilinux2')");

query.exec("insert into course values (3,'Computer','yafeilinux3')");

return true;

}

#endif // DATABASE_H

我们在这里建立了两个表,student表中有一项是course,它是int型的,而course表的主键也是int型的。如果要将course项和course表进行关联,它们的类型就必须相同,一定要注意这一点。

然后将main.cpp中的内容更改如下:

#include

#include "widget.h"

#include "database.h"

int main(int argc, char *argv[])

{

QApplication a(argc, argv);

if(!createConnection()) return 1;

Widget w;

w.show();

return a.exec();

}

我们在widget.h中添加头文件:#include

然后在private中声明对象:QSqlRelationalTableModel *model;

我们在widget.ui中添加一个Table View部件到窗体上,然后到widget.cpp中的构造函数里添加如下代码:

model = new QSqlRelationalTableModel(this);

model->setEditStrategy(QSqlTableModel::OnFieldChange); //属性变化时写入数据库

model->setTable("student");

model->setRelation(2,QSqlRelation("course","id","name"));

//将student表的第三个属性设为course表的id属性的外键,并将其显示为course表的name属性的值

model->setHeaderData(0, Qt::Horizontal, QObject::tr("ID"));

model->setHeaderData(1, Qt::Horizontal, QObject::tr("Name"));

model->setHeaderData(2, Qt::Horizontal, QObject::tr("Course"));

model->select();

ui->tableView->setModel(model);

我们修改了model的提交策略,OnFieldChange表示只要属性被改动就马上写入数据库,这样就不需要我们再执行提交函数了。setRelation()函数实现了创建外键,注意它的格式就行了。

运行效果如下:

可以看到Course属性已经不再是编号,而是具体的课程了。关于外键,你也应该有一定的认识了吧,说简单点就是将两个相关的表建立一个桥梁,让它们关联起来。

那么我们也希望,如果用户更改课程属性,那么他只能在课程表中有的课程中进行选择,而不能随意填写课程。在Qt中的QSqlRelationalDelegate委托类就能实现这个功能。我们只需在上面的构造函数的最后添加一行代码:

ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->tableView));

添加代理(委托),在我这里不知为什么会出现SqlRelationalDelegate is not a type name的提示,不过可以编译通过。

我们需要在widget.cpp中添加头文件:#include

运行效果如下:

可以看到这时修改Course属性时,就会出现一个下拉框,只能选择course表中的几个值。

而利用这个类来操作数据库,与前面讲到的QSqlTableModel没有区别,这里就不再重复。这几篇文章一共讲了好几种操作数据库的方法,到底应该使用哪个呢?那就看你的需求了,根据这几种方法的特点进行选择吧。

qsql 关联_QSqlRelationalTableModel使用方法 | 学步园相关推荐

  1. matlab如何进对图像进行透视变换,在Matlab中实现透视变换的方法 | 学步园

    透视变换在两幅图像中进行对应非常有用,看下面的两幅图 第一幅图是源图像,图中有五个点,分别是四个顶点和中间的一个点(对应目标图中的中心点) 第二幅图是目标图,包括与源图像中的五个点对应的五个点 下面就 ...

  2. python最简单单例模式_Python单例模式的4种实现方法 | 学步园

    Python单例模式的4种实现方法: 方法1: 实现__new__方法,并将一个类的实例绑定到类变量_instance上.如果cls._instace为None,说明该类还未实例化过,实例化该类,并返 ...

  3. java 调用cpp_java jni 调用cpp文件中的方法 | 学步园

    这里说下最近修改nutch的源码碰到的调用cpp文件中的方法. 刚刚开始的时候,想直接在fetch.java中直接写jni接口.后来发现这样会留下不好的编程习惯.自己动手在fetch下写一个类.Hel ...

  4. teraterm 执行sql命令_tera term的ttl脚本使用方法 | 学步园

    1.环境构筑 1.安装Tera Term. 下载路径如下: 2.安装可运行的PFC环境 2.运用TTL脚本进行自动测试 TTL脚本的命名一览和相关介绍请参考Tera Term的help文件. TTL脚 ...

  5. c 导入数据到oracle,excel中数据导入到Orcale数据库表中的方法 | 学步园

    最近我们要做产品的测试,由于里面的数据量太少,上头要我往数据库的表里加上10000条记录.我想如果一条一条地往里加,还不要几个月呀,人也要被累死.所以,我很快地就想到了利用工具加. 就上网搜索,大多介 ...

  6. Derby与mysql的关系_Derby数据库简单介绍和使用方法 | 学步园

    一. Derby 数据库介绍 Apache Derby 是100% Java 编写的内存数据库,属于 Apache 的一个开源项目.并且是一个容易管理的关系数据库管理系统,可以和一些商业产品的特性进行 ...

  7. java dll 调用方法_关于Java调用dll的方法 | 学步园

    Java语言本身具有跨平台性,如果通过Java调用DLL的技术方便易用,使用Java开发前台界面可以更快速,也能带来跨平台性. Java调用C/C   写好的DLL库时,由于基本数据类型不同.使用字节 ...

  8. java的set和get方法实例化_java反射机制 调用get set 方法 | 学步园

    调用get set 方法,需要 某一个类  类中的字段  字段的值来实现 代码: package entity; import java.lang.reflect.Method; import jav ...

  9. python层次聚类_python中做层次聚类,使用scipy.cluster.hierarchy.fclusterdata方法 | 学步园...

    python机器学习包里面的cluster提供了很多聚类 但是没有看明白ward_tree的返回值代表了什么含义,遂决定寻找别的实现方式. 经过查找,发现scipy.cluster.hierarchy ...

最新文章

  1. 刷爆 AI 圈!基于 Transformer 的 DALL-E 代码刚刚开源了
  2. AGG第十一课 agg::ellipse 渲染椭圆和多边形
  3. 每日一皮:程序员和黑客的区别
  4. [转载]从12306谈起验证码的架构
  5. CentOS6.4安装Samba(匿名)共享服务器
  6. ubuntu查看版本
  7. leetcode369. 给单链表加一
  8. flutter release 版本 调试_腾讯课堂Flutter工程实践系列——接入篇
  9. 爱情测试MySQL存储_性能测试四十:Mysql存储过程造数据
  10. 阿里云上云迁移工具案例实践:腾讯云迁移到阿里云
  11. greenplum,teradata,presto,clickhouse四种分布式数据库的对比
  12. MongoDB文档增删改查
  13. 登录GITHUB:Open your two-factor authenticator (TOTP) app or browser extension to view your authenticat
  14. cairo填充_用 cairo 实现跨平台图形
  15. 计算机图文混合排版教学设计,Word图文混排教学设计
  16. java程序性能优化(实例)
  17. c++ 字符串流 sstream(常用于格式转换)
  18. 常用模型、分析方法及其检验标准累积汇总
  19. 极客爱情 2.1 | 从你的编程世界路过
  20. JavaScript 中 OnLoad事件用法总结

热门文章

  1. leaflet 中文官网,再也不用费劲找了直接一步到位
  2. 博图os更新_西门子PLC固件如何操作更新?
  3. 燕山大学计算机毕业论文,燕山大学本科(毕业论文)格式.doc
  4. 青龙面板之短信登录非阿东,爱跑路的开源项目安装教程。【大老又跑路了】
  5. 计算机教育2018,2018计算机专业大学排名【教育部】
  6. linux中管道符号和追加符号(覆盖符号)的用法简介
  7. NTP时钟服务器IP地址配置方法(海康大华版)
  8. CentOS7.4安装部署openstack[Liberty版](1)
  9. python3爬虫技术路线
  10. 记录自己p751dm2几乎完美黑苹果的历程