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,如需转载请自行联系原作者

目录
相关文章
|
9月前
|
SQL 数据库 C++
C/C++ Qt 数据库QSql增删改查组件应用
Qt SQL模块是Qt中用来操作数据库的类,该类封装了各种SQL数据库接口,可以很方便的链接并使用,数据的获取也使用了典型的Model/View结构,通过MV结构映射我们可以实现数据与通用组件的灵活绑定,一般SQL组件常用的操作,包括,读取数据,插入数据,更新数据,删除数据,这四个功能我将分别介绍它是如何使用的。
243 0
C/C++ Qt 数据库QSql增删改查组件应用
|
9月前
|
SQL 数据库 C++
C/C++ Qt 数据库与TreeView组件绑定
在上一篇博文`《C/C++ Qt 数据库QSql增删改查组件应用》`介绍了Qt中如何使用SQL操作函数,并实现了对数据库的增删改查等基本功能,从本篇开始将实现数据库与View组件的绑定,通过数据库与组件关联可实现动态展示数据库中的表记录。
198 0
C/C++ Qt 数据库与TreeView组件绑定
|
9月前
|
存储 SQL 数据库
C/C++ Qt 数据库与ComBox多级联动
Qt中的SQL数据库组件可以与`ComBox`组件形成多级联动效果,在日常开发中多级联动效果应用非常广泛,例如当我们选择指定用户时,我们让其在另一个`ComBox`组件中列举出该用户所维护的主机列表,又或者当用户选择省份时,自动列举出该省份下面的城市列表等。
246 0
C/C++ Qt 数据库与ComBox多级联动
|
9月前
|
存储 数据库 C++
C/C++ Qt 数据库与TableView多组件联动
Qt 数据库组件与TableView组件实现联动,以下案例中实现了,当用户点击并选中TableView组件内的某一行时,我们通过该行中的name字段查询并将查询结果关联到`ListView`组件内,同时将TableView中选中行的字段分别显示在窗体底部的`LineEdit`编辑内,该案例具体实现细节如下。
240 0
C/C++ Qt 数据库与TableView多组件联动
|
9月前
|
SQL 数据库 C++
C/C++ Qt 数据库与SqlTableModel组件应用
SqlTableModel 组件可以将数据库中的特定字段动态显示在`TableView`表格组件中,通常设置`QSqlTableModel`类的变量作为数据模型后就可以显示数据表内容,界面组件中则通过`QDataWidgetMapper`类实例设置为与某个数据库字段相关联,则可以实现自动显示字段的内容,不仅是显示,其还支持`动态增删改查`等各种复杂操作,期间不需要使用任何SQL语句。
269 0
C/C++ Qt 数据库与SqlTableModel组件应用
|
9月前
|
存储 数据库 C++
C/C++ Qt 数据库SqlRelationalTable关联表
在上一篇博文中详细介绍了`SqlTableModle`组件是如何使用的,本篇博文将介绍`SqlRelationalTable`关联表组件,该组件其实是`SqlTableModle`组件的扩展类,`SqlRelationalTable`组件可以关联某个主表中的外键,例如将主表中的某个字段与附加表中的特定字段相关联起来,`QSqlRelation(关联表名,关联ID,名称)`就是用来实现多表之间快速关联的。
189 5
C/C++ Qt 数据库SqlRelationalTable关联表
|
10月前
|
存储 SQL 数据库
C/C++ Qt 数据库与Chart实现历史数据展示
在前面的博文中具体介绍了QChart组件是如何绘制各种通用的二维图形的,本章内容将继续延申一个新的知识点,通过数据库存储某一段时间节点数据的走向,当用户通过编辑框提交查询记录时,程序自动过滤出该时间节点下所有的数据,并将该数据动态绘制到图形组件内,实现动态查询图形的功能。
223 0
C/C++ Qt 数据库与Chart实现历史数据展示
|
存储 监控 BI
案例分享:Qt+RV1126+PLC医疗血浆采集仪(中英文输入、西门子PLC、数据库存储,各种数据统计,数值监测,电子秤操作,记录查询,全局报警等等)
案例分享:Qt+RV1126+PLC医疗血浆采集仪(中英文输入、西门子PLC、数据库存储,各种数据统计,数值监测,电子秤操作,记录查询,全局报警等等)
案例分享:Qt+RV1126+PLC医疗血浆采集仪(中英文输入、西门子PLC、数据库存储,各种数据统计,数值监测,电子秤操作,记录查询,全局报警等等)
|
SQL 数据库连接 数据库
Qt实用技巧:Qt连接SQL Server数据库(需要配置ODBC)
Qt实用技巧:Qt连接SQL Server数据库(需要配置ODBC)
|
SQL 数据库 计算机视觉
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
Qt实用技巧:使用QTableView、QSqlTableMode与QSqlDatabase对数据库数据进行操作
推荐文章
更多
推荐镜像
更多