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 是该窗口部件要占用的列数。如果 rowSpin columnSpin 省略会默认是值为 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,如需转载请自行联系原作者

目录
相关文章
|
5月前
|
存储 SQL 数据库
C++ Qt开发:数据库与TableView多组件联动
在Qt中,通常我们不会在`TableView`等组件中保存数据,一般会将这些数据存储至数据库或者是文件中保存,当使用时则动态的在数据库中调出来,以下案例将实现,当用户点击并选中`TableView`组件内的某一行时,我们通过该行中的`name`字段查询,并将查询结果关联到`ListView`组件内,同时将`TableView`中选中行的字段分别显示在窗体底部的`LineEdit`编辑框内。Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍`TableView`
C++ Qt开发:数据库与TableView多组件联动
|
5月前
|
SQL 数据库 C++
C++ Qt开发:Charts与数据库组件联动
Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍`Charts`组件与`QSql`数据库组件的常用方法及灵活运用。在之前的文章中详细介绍了关于`QCharts`绘图组件的使用方式,本章将继续延续这个知识点,通过使用`QSql`数据库模块动态的读取某一个时间节点上的数据,当用户点击查询数据时则动态的输出该事件节点的所有数据,并将数据绘制到图形组件内,实现动态查询图形的功能。
C++ Qt开发:Charts与数据库组件联动
|
5月前
|
SQL 数据库连接 数据库
C++ Qt开发:QSqlDatabase数据库组件
Qt SQL模块是Qt框架的一部分,它提供了一组类和函数,用于在Qt应用程序中进行数据库操作。这个模块的目标是简化数据库访问和操作,并提供一致的接口,使得开发者可以方便地与不同数据库系统进行交互。一般SQL组件常用的操作,包括读取数据、插入数据、更新数据、删除数据功能,这四个功能我将分别介绍它是如何使用的。Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍`QSqlDatabase`数据库模块的常用方法及灵活运用。
C++ Qt开发:QSqlDatabase数据库组件
|
11月前
|
Oracle 关系型数据库 MySQL
Qt数据库开发的一些冷知识
Qt数据库开发的一些冷知识
|
11月前
|
存储 设计模式 Cloud Native
C++QT SqlLite数据库简单使用
C++QT SqlLite数据库简单使用
|
12月前
|
存储 SQL 关系型数据库
linux系统中使用QT来实现数据库的调用方法
linux系统中使用QT来实现数据库的调用方法
98 0
|
关系型数据库 MySQL 数据库
数据库练习
数据库练习
78 0
|
4月前
|
存储 前端开发 小程序
表白墙完善(数据库,前端,后端Servlet),再谈Cookie和Session。以及一个关于Cookie的练习小程序
表白墙完善(数据库,前端,后端Servlet),再谈Cookie和Session。以及一个关于Cookie的练习小程序
|
12天前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
|
4月前
|
数据库 数据安全/隐私保护 数据库管理
QT中sqlite数据库数据加密/混淆---MD5/SHA1/SHA2/SHA3
QT中sqlite数据库数据加密/混淆---MD5/SHA1/SHA2/SHA3

推荐镜像

更多