开发者社区> 余二五> 正文

Qt 数据库练习

简介:
+关注继续查看
最近没有更新博客了,网上搜索资料做点关于Qt的登陆界面及数据库的语句、数据库执行模式、数据库表格模式等。资料网址:http://hi.baidu.com/yafeilinux/blog/item/a335cd10a465d174cb80c42d.html http://hi.baidu.com/yafeilinux/blog/index/4
做了一个关于Qt数据库的小实验,登陆界面与一般的登陆界面很相似,登陆界面包括:用户姓名、用户密码、登陆的按钮、退出的按钮,测试程序运行的登陆界面的效果如下:
数据库视图模式有以下几个功能:添加记录、删除记录、更新记录(修改记录和撤销修改)、排序分为升序排列和降序排列、查询、返回全表等有显示效果如下:
嘿嘿....其实也不是很难,接下来实现这些功能.现在开始简易的说一个制作流程:
先做一个用表格视图来显示数据库的数据的对话框。先建一个名为QSQLITE项目工程的目录,新建一个main.cpp主函数源文件,在主函数创建一个实例化继承公共对话框类的对象Sqlite并且把对话框Sqlite对话框窗口部件显现出来,设置支持的字符集为GBK,接着声明对话框的窗口部件的类,创建窗口部件的对象。最后布局对话框的部件。布局Sqlite对话框窗口部件,我的思路是这样的。先布局右边的六个Button按钮。采用垂直布局方式。左边的窗口部件采用栅格布局布局窗口部件,然后再用一个总的栅格布局来设置布局的排布位置。
现在来做布局的第一步:
设置主函数,显示字符集为GBK
Sqlite对话框类的声明,按钮和垂直布局对象的创建
sqlite.cppC++源程序文件,添加布局,我在系统终端直接编辑中文是不允许的,只能在主菜单附件在文本编辑器打开sqlite.cpp源文件,输入中文,保存。再到系统终端打开sqlite.cpp的时候,中文变成了乱码。然后再次编辑button的文本显示内容。设置按钮的布局是垂直布局,设置标题对话框标题为SQLITE.然后保存就可以了。不知道有没有更好的解决中文输入的方法。
浏览一下布局按钮的效果:
接着布局左边的窗口部件表格视图窗口部件、标签、行编辑器、按钮及栅格布局等。类的声明及对象的创建
用栅格布局可以精确的设置窗口部件的排放位置及占用的行列。QGridLayout::addWidget()的调用遵循的语法形式:
gridLayout->addWidget(widget,row,column,rowSpan,columnSpan);
widget是要插入到布局中的子窗口部件,(row,column)是由该窗口部件所占用的左上角单元格。接着是后面的两个参数,上次我说错了,我说的是左上角单元格坐标的对角坐标。准确的说法rowSpin是该窗口部件要占用的行数,而columnSpin是该窗口部件要占用的列数。如果rowSpincolumnSpin省略会默认是值为1.在用一个总的栅格布局管理器,布局垂直布局和子栅格布局。
然后再重新构建文件,在执行可以执行文件,预览效果如下:
接着设置一些关于数据库的操作,使用数据库驱动为QSQLITE,链接数据库命名为test,然后用if判断语句判断是否打开数据库,执行类对象创建,执行SQL语句。打开数据库有几个步骤:(1)使用驱动的说明(2)数据库链接打开数据库(3)执行SQL数据库语句(4)关闭数据库连接
连接数据库的判断如果连接不成功返回1
sqlite.h声明QSqlTableModel模式类,创建一个数据库表格模式对象model
设置数据库表格运作模式表格名为student,用数据库表格模式设置表格,使用指定的筛选和排列条件,如果成功返回true,否则返回false。然后用表格视图显示这个数据库表格模式内容。
程序要运用到数据库驱动,所以要在工程中添加Qt sql库。
预览程序的运行效果
添加信号与槽链接,在sqlite.h声明信号槽的函数。就是当点击button时,就是激活对应槽的函数,在添加一个Q_OBJECT信号与槽的宏定义。
对应的Button按钮有对应的信号与槽
调用对应的槽函数,来实现对于的功能。添加记录、删除记录、修改记录、撤销修改功能
接下来是实现升序排列、降序排列、查找、返回全表功能等
 
还未写完。。。









本文转自 chen138 51CTO博客,原文链接:http://blog.51cto.com/chenboqiang/328675,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
如何设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云安全组设置详细图文教程(收藏起来) 阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程。阿里云会要求客户设置安全组,如果不设置,阿里云会指定默认的安全组。那么,这个安全组是什么呢?顾名思义,就是为了服务器安全设置的。安全组其实就是一个虚拟的防火墙,可以让用户从端口、IP的维度来筛选对应服务器的访问者,从而形成一个云上的安全域。
19229 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
28493 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
22266 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
15917 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
20369 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
23547 0
腾讯云服务器 设置ngxin + fastdfs +tomcat 开机自启动
在tomcat中新建一个可以启动的 .sh 脚本文件 /usr/local/tomcat7/bin/ export JAVA_HOME=/usr/local/java/jdk7 export PATH=$JAVA_HOME/bin/:$PATH export CLASSPATH=.
14884 0
+关注
20378
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载