ImageVerifierCode 换一换
格式:DOC , 页数:4 ,大小:116.50KB ,
资源ID:12040760      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/12040760.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(二十七、Qt数据库(七)QSqlRelationalTableModel.doc)为本站上传会员【仙人****88】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

二十七、Qt数据库(七)QSqlRelationalTableModel.doc

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 #include static bool createConnection() {     QSqlDatabase db = QSqlDatabase::addDatabase(“QSQLITE”);     db.setDatabaseName(“database.db”);     if(!db.open()) return false;     QSqlQuery query;     query.exec(“create tab

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 #include “widget.h” #include “database.h” int main(int argc, char *argv[]) {     QApplication a(argc, argv);     if(!createConnection()) retu

6、rn 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->setEd

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 运行效果如下: 可以看到这时修改Course属性时,就会出现一个下拉框,只能选择course表中的几个值。 而利用这个类来操作数据库,与前面讲到的QSqlTableModel没有区别,这里就不再重复。这几篇文章一共讲了好几种操作数据库的方法,到底应该使用哪个呢?那就看你的需求了,根据这几种方法的特点进行选择吧。 分类:Qt系列教程 作者: yafeilinux 日期: 四月 30th, 2010.    244 vi

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’ 谢谢啦!

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服