1、讲完QSqlTableModel了,我们这次讲这个类的扩展类QSqlRelationalTableModel,它们没有太大的不同,唯一的就是后者在前者的基础之上添加了外键(或者叫外码)的支持。 QSqlRelationalTableModel,该类为单张的数据库表提供了一个可编辑的数据模型,它支持外键。 我们还是新建Qt4 Gui Application工程,我这里工程名为relationalTableModel ,然后选中QtSql模块,Base class选QWidget。工程建好后,添加C++ Header File ,命名为database.h,更改其内容如下: #ifnd
2、ef DATABASE_H
#define DATABASE_H
#include
3、le 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
4、 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 我们在这
5、里建立了两个表,student表中有一项是course,它是int型的,而course表的主键也是int型的。如果要将course项和course表进行关联,它们的类型就必须相同,一定要注意这一点。
然后将main.cpp中的内容更改如下:
#include
6、rn 1;
Widget w;
w.show();
return a.exec();
}
我们在widget.h中添加头文件: #include
7、itStrategy(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->setHeade
8、rData(1, Qt::Horizontal, QObject::tr(“Name”)); model->setHeaderData(2, Qt::Horizontal, QObject::tr(“Course”)); model->select(); ui->tableView->setModel(model); 我们修改了model的提交策略,OnFieldChange表示只要属性被改动就马上写入数据库,这样就不需要我们再执行提交函数了。setRelation()函数实现了创建外键,注意它的格式就行了。 运行效果如下: 可以看到Course属性已经
9、不再是编号,而是具体的课程了。关于外键,你也应该有一定的认识了吧,说简单点就是将两个相关的表建立一个桥梁,让它们关联起来。 那么我们也希望,如果用户更改课程属性,那么他只能在课程表中有的课程中进行选择,而不能随意填写课程。在Qt中的QSqlRelationalDelegate委托类就能实现这个功能。我们只需在上面的构造函数的最后添加一行代码: ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->tableView)); 添加代理(委托),在我这里不知为什么会出现SqlRelationalDelegate is not
10、 a type name的提示,不过可以编译通过。
我们需要在widget.cpp中添加头文件: #include
11、ews Tags: creator, qt, yafeilinux, 教程, 数据库 2 条评论 在 “二十七、Qt数据库(七)QSqlRelationalTableModel” 1. ding404 说: 2010年05月26日于9:27 上午 学习完毕n(0_0)n, 谢谢楼主。针对lanyu的问题,可能是由于你的代码是复制网页上的,这样可能student name 或者course name的单引号格式有问题,需要手动改回来,否则编译能通过,但是运行的时候表格里啥都不显示。我也是找了很久才发现这个问题,编译不会有错的。。。。。 2. lanyu 说: 2010年05月17日于11:58 下午 请问,为什么我的运行结果里显示不出表格里的内容,只有个表格?加入 ui->tableView->setItemDelegate(new QSqlRelationalDelegate(ui->tableView));和#include 后,出现 error: expected type-specifier before ‘QSqlRelationDelegate’ 谢谢啦!






