当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]Qt 数据库编程

现在我们讲使用数据库来进行变成,具体的提供了SELECT INSERT UPDAte DELETE等数据库的执行语句,这是在数据库的接口,当在图形下显示数据时需要使用到QSqlTableModel。所以在数据库编程之前需要掌握基础的SQL 命令语句。

数据库驱动层

相关联的类包含了QSqlDriver ,QSqlDriverCreatpor ,QSqlDriverCreatorBase,QSqlDriverPlugin与QSqlResult 。

数据库的应用程序接口层

这些类提供了访问数据库,提出一个连接请求,如同文件访问一样,当连接成功,讲通过判断信息返回信息,只要建立了连接就可以使用QSqlQuery 类来操作数据库, 在连接数据库之后还提供了几个类, 例如QSqlError ,QSqlField ,QSqlIndex 与QSqlRecord。

用户接口层

这些类提供了与数据相关的部件,包含了QSqlQueryModel,QSqlTableModel,与QSqlRelatiONTableModel 。这些类的定义使用是用来提供数据库的模式与试图来设计的。

连接到数据库

如果要建立一个数据库的连接, 首先要知道使用的什么数据库,并为这个数据库的连接加载驱动,如果是mysql 数据库,都会有用户名与密码,这也是必须设置的,被连接的数据库或许在本地或者在远程的某台计算机上,所以需要设置一个主机的名称来区别。

下面是连接数据库的例子:

QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");

db.setHoSTname("bigblue");

db.setDatabaseNAME("flightdb");

db.setUserName("acarlson");

db.setPassword("1uTbSbAs");

bool k = db.open();

我们同时也可以建立两个数据库的连接:

QSqlDatabase firstDB = QSqlDatabase::addDatabase("QMYSQL", "first");

QSqlDatabase secondDB = QSqlDatabase::addDatabase("QMYSQL", "second");

在打开数据库的时候有可能会发生错误,这里提供了一个静态的函数,QSqlDatabase::lastError() 来返回当前所发生的错误。与文件相同当打开了一个数据的时候,需要在操作完毕后关闭数据库,使用QSqlDatabase::close(),之后调用QSqlDatabase::removeDatabase().

执行数据库语句

QSqlQuery 提供了执行数据库语句的方法,它可以返回所有的执行结果。当建立好数据库连接后可以使用QSqlQuery::exec() 如同下面的语句:

QSqlQuery query;

query.exec("SELECT name, salary FROM employee WHERE salary > 50000");

当QSqlQuery 建立了一个构造之后,将会接受特定的QSqlDatabase 对象连接来使用,正如上面的代码 。

浏览查询结果

QSqlQuery 当执行exec() 之后将会把指针放在记录第一个记录之上,所以需要调用QSqlQuery::next()来获取第一个数据下面的代码,通过一个循环体来便利所有表中的数据:

while (query.next()) {

QString name = query.value(0).toString();

int salary = query.value(1).toInt();

qDebug() << name << salary;

}

QSqlQuery::value() 函数当前记录区域中的数据,作为默认的QSqlValue::value()返回的是一个QVariant类型。提供了几种可选类型的支持,他们是C++ 的基本的类型,比如int QString 与QByteArray 。对于不同类型的转换使用Qt 提供的函数来是想,例如 QVariant::toString 与QVariant::toInt() 。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

本文中,小编将对PLC予以介绍,如果你想对它的详细情况有所认识,或者想要增进对它的了解程度,不妨请看以下内容哦。

关键字: PLC 编程

在下述的内容中,小编将会对PLC的相关消息予以报道,如果PLC是您想要了解的焦点之一,不妨和小编共同阅读这篇文章哦。

关键字: PLC 编程 模块化

北京——2025年8月15日,亚马逊云科技日前宣布,Amazon DocumentDB Serverless已正式可用,这是Amazon DocumentDB(兼容MongoDB)的一种全新配置,能够根据应用程序需求自动...

关键字: 数据库 服务器

济南2025年8月12日 /美通社/ -- 近年来,国家大力推进信创产业发展,明确要求关键行业信息系统实现 "自主可控、安全可靠",老年教育领域作为民生服务的重要阵地,其信息化建设的国产化适配已成为行...

关键字: 全栈 BSP 数据库 加密

助力企业更快、更轻松地迁移VMware工作负载,无需重构应用或变更架构

关键字: 云服务 生成式AI 数据库

-Cognizant正在筹办全球最大规模的氛围编程活动,以提升数千名员工的AI素养 为抓住人工智能经济将创造的巨大机遇,Cognizant与Lovable、Windsurf、Cursor、Gemini Code Ass...

关键字: 编程 NI AN PI

在云计算与数据库高可用场景中,LVM(Logical Volume Manager)的动态扩展能力已成为保障业务连续性的关键技术。某金融企业通过LVM在线扩容将数据库停机时间从2小时缩短至30秒,但操作不当仍可能导致数据...

关键字: LVM 数据库

即日起,客户可以在亚马逊云科技北弗吉尼亚区域和俄勒冈区域使用Oracle Database@Amazon Web Services,后续将扩展至全球其他20个区域。 富达投资集团、全美互惠保险公司(Nation...

关键字: DATABASE ORACLE SERVICES 亚马逊

北京 2025年7月10日 /美通社/ -- 全球向量数据库的先行者Zilliz利用亚马逊云科技的生成式AI技术与云服务,为全球企业及开发者提供高可扩展、安全稳定的向量数据库解决方案,助力企业全面释放数据潜能。此外,依...

关键字: 亚马逊 向量 数据库 AI

上海 2025年6月23日 /美通社/ -- 日前,以"汇聚•连接•创造"为主题的2025世界移动通信大会(MWC)上海拉开帷幕。大会期间,爱立信专家围绕"5G-A","...

关键字: 爱立信 编程 网络 AI
关闭