QT上位机开发(MySql访问)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

        网上介绍的关于QT和mysql部分的内容,都是利用Qt自带的mysql库来实现数据读写的。但是事实上来说,即使不用qt带的库,不用odbc,直接使用mysql安装包自带的lib库和dll库,也是可以实现数据访问的,而且也并不复杂。今天,我们正好借着这个机会学习一下,在qt上面怎么使用mysql自带的库进行数据访问。

1、安装mysql软件

        这部分可以安装稍微旧一点、但是比较稳定的软件。

2、创建qt widget工程

        创建一个qt widget工程,为后续的软件修改做准备。需要注意的是,因为使用的mysql lib库和dll库,他们都是64位的,所以创建qt widget的时候,也必须是64位的。

3、用mysql命令创建一个demo databases

        一般创建的databases命令就是create databases demo。创建好demo数据库之后,直接show一下就可以了。

4、设置include目录

        因为涉及到mysql头文件目录的位置,所以include一下,

C:\Program Files\MySQL\MySQL Server 5.7\include

5、设置lib文件

        很多时候并不需要设置lib目录,lib文件少的话,直接设置带目录的lib文件即可,

C:\Program Files\MySQL\MySQL Server 5.7\lib\libmysql.lib

6、将lib目录下面的dll文件copy到exe同级目录

        这部分工作可以提前做,不然到时候debug的时候,是启动不了的。

7、编写源代码、编译调试

        源代码的部分,其实就比较简单了。首先就是mysql_init初始化,接着用mysql_real_connect链接数据库。后续的动作基本就是sop了,比如创建表、插入数据、更新数据、删除数据、查找数据、打印数据等等,这部分找到对应的api,一个一个去调试即可。当然,结束的时候,最好把mysql的资源也要一个一个去释放掉。

#include <stdio.h>
#include <stdlib.h>
#include <mysql.h>// Function to handle errors
void handle_error(MYSQL *conn, const char *message) {fprintf(stderr, "%s: %s\n", message, mysql_error(conn));mysql_close(conn);exit(1);
}int main() {MYSQL *conn;// Initialize MySQL libraryconn = mysql_init(NULL);if (conn == NULL) {fprintf(stderr, "mysql_init() failed\n");exit(1);}// Connect to MySQL serverif (mysql_real_connect(conn, "localhost", "root", "12345678", "demo", 0, NULL, 0) == NULL) {handle_error(conn, "mysql_real_connect() failed");}// Create a table (if it doesn't exist)if (mysql_query(conn, "CREATE TABLE IF NOT EXISTS your_table (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255))")) {handle_error(conn, "mysql_query() failed for CREATE TABLE");}// Example: Insert dataif (mysql_query(conn, "INSERT INTO your_table (name) VALUES ('John'), ('Jane')")) {handle_error(conn, "mysql_query() failed for INSERT");}// Example: Update dataif (mysql_query(conn, "UPDATE your_table SET name = 'Johnny' WHERE id = 1")) {handle_error(conn, "mysql_query() failed for UPDATE");}// Example: Delete dataif (mysql_query(conn, "DELETE FROM your_table WHERE id = 2")) {handle_error(conn, "mysql_query() failed for DELETE");}// Example: Query dataif (mysql_query(conn, "SELECT * FROM your_table")) {handle_error(conn, "mysql_query() failed for SELECT");}// Retrieve and print resultsMYSQL_RES *result = mysql_store_result(conn);if (result == NULL) {handle_error(conn, "mysql_store_result() failed");}MYSQL_ROW row;while ((row = mysql_fetch_row(result))) {printf("ID: %s, Name: %s\n", row[0], row[1]);}// Free result setmysql_free_result(result);// Close connectionmysql_close(conn);// Cleanup MySQL librarymysql_library_end();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/631006.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用 ChatGPT 高效搜索:举一反三的思考方式,高效查找解决方案

文章目录 基础思路举一反三Go 语言 Web 框架延伸思考思考结论 本文只是我的一些尝试&#xff0c;基于 ChatGPT 实现系统化快速搜索某编程语言的特定领域相关包或者基于其他语言类推荐落地方案的尝试。 这篇文章中描述的方式不一定是好方式&#xff0c;但应该会有一定的启示作用…

深入剖析 Git 对象底层原理

一、引言 在我们日常使用 Git 时&#xff0c;通常的操作是&#xff1a; 在写完一段代码后&#xff0c;执行 git add命令&#xff0c;将这段代码添加到暂存区中然后再执行 git commit和 git push 命令&#xff0c;将 本地 Git 版本库中的提交同步到服务器中的版本库中 Git 在…

vscode 格式化代码

在 Visual Studio Code 中&#xff0c;你可以使用以下步骤来格式化代码&#xff1a; 打开你的代码文件。选择你要格式化的代码部分或按 CtrlA 来全选。按下 ShiftAltF&#xff0c;这会触发 "格式化文档" 的命令。 如果你的键盘布局没有 "Alt" 键&#xf…

Three.js 学习笔记之模型(学习中1.17更新)

文章目录 模型 几何体 材质模型点模型Points - 用于显示点线模型Line | LineLoop | LineSegments网格模型mesh - 三角形 几何体BufferGeometry缓冲类型几何体BufferGeometry - 没有任何形状的空几何体创建几何体的方式BufferAttribute Types定义顶点法线 geometry.attributes…

Maven工程 — 继承与聚合 相关知识点详解

简介&#xff1a;这篇帖子主要讲解Maven工程中的继承与聚合的相关知识点&#xff0c;用简洁的语言和小编自己的理解&#xff0c;深入浅出的说明Maven工程的继承与聚合。 目录 1、继承 1.1 继承关系的实现 1.2 版本锁定 2、聚合 2.1 聚合方法 3、总结 1、继承 图 1-1 继承…

2018年认证杯SPSSPRO杯数学建模C题(第一阶段)机械零件加工过程中的位置识别全过程文档及程序

2018年认证杯SPSSPRO杯数学建模 基于轮廓特征的机械零件位置识别研究 C题 机械零件加工过程中的位置识别 原题再现&#xff1a; 在工业制造自动生产线中&#xff0c;在装夹、包装等工序中需要根据图像处理利用计算机自动智能识别零件位置&#xff0c;并由机械手将零件自动搬…

[go语言]输入输出

目录 知识结构 输入 1.Scan ​编辑 2.Scanf 3.Scanln 4.os.Stdin --标准输入&#xff0c;从键盘输入 输出 1.Print 2.Printf 3.Println 知识结构 输入 为了展示集中输入的区别&#xff0c;将直接进行代码演示。 三者区别的结论&#xff1a;Scanf格式化输入&#x…

【Ubuntu】使用NFS共享挂载硬盘

在Ubuntu系统上使用NFS&#xff08;Network File System&#xff09;将某个硬盘挂载并在另一个Ubuntu系统上进行挂载的过程可以分为两个步骤&#xff1a;一是将硬盘挂载到服务器上&#xff0c;二是在客户端上挂载这个共享。 以下是详细步骤&#xff1a; 在服务器上挂载硬盘并…

Python中re模块search和findall函数的使用

1.search函数&#xff1a; re.search(pattern,string,flags0) 用于整个字符串中搜索第一个匹配的值&#xff0c;如果匹配成功&#xff0c;结果为Match对象&#xff0c;否则结果位None。 import re pattern\d\.\d sI study Python3.11 every day Python2.7 I love you matchr…

ElasticSearch(1):Elastic Stack简介

1 简介 ELK是一个免费开源的日志分析架构技术栈总称&#xff0c;官网https://www.elastic.co/cn。包含三大基础组件&#xff0c;分别是Elasticsearch、Logstash、Kibana。但实际上ELK不仅仅适用于日志分析&#xff0c;它还可以支持其它任何数据搜索、分析和收集的场景&#xf…

MongoDB面试系列-02

1. MongoDB 中必须调用 getLastError 来确保写操作生效吗&#xff1f; MongoDB中不管有没有调用getLastError&#xff08;又称为Safe Mode&#xff09;&#xff0c;服务器执行的操作都会一样。 而调用getLastError只是为了确认写操作是否成功提交&#xff0c;但是写操作的安全…

MySQL中根据出生日期计算年龄

创建student表 mysql> create table student( -> sid int primary key comment 学生号, -> sname varchar(20) comm…

「实战应用」如何用DHTMLX Gantt构建类似JIRA式的项目路线图(二)

DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的所有需求&#xff0c;是最完善的甘特图图表库。 在web项目中使用DHTMLX Gantt时&#xff0c;开发人员经常需要满足与UI外观相关的各种需求。因此他们必须确定JavaScript甘特图库的…

Android Studio由于开启代理无法下载依赖,一直在Build model

一、问题描述 正常打开AS项目&#xff0c;一直显示Build model就是不下载依赖 二、问题解决 1、首先选择No Proxy&#xff0c;可以看到这位同学之前是使用的代理。 2、打开下面文件&#xff0c;然后删除某尾的4行。 3、面对提示框&#xff0c;直接点击OK。 4、然后停…

IIS 缓存, 更新后前端资源不能更新问题

解决办法: 通常只需要index.html 不缓存即可, 其他文件都是根据index.html 中的引用去加载; 正确的做法是在 站点下增加 web.config 文件, 内容如下: 我这个是因为目录下有个config.js 配置文件, 也不能缓存, 所以加了两个 <?xml version"1.0" encoding&quo…

基于Python flask的猫眼电影票房数据分析可视化系统,可以定制可视化

技术方案 猫眼电影票房数据分析可视化系统是基于Python Flask框架开发的一款用于分析和展示猫眼电影票房数据的Web应用程序。该系统利用Flask提供了一个简单而强大的后端框架&#xff0c;结合Request库进行网络爬虫获取猫眼电影票房数据&#xff0c;并使用Pyecharts进行可视化…

消息中间件面试题

目录 一.为什么使用消息队列 二.RabbitMQ 1.RabbitMQ如何保证消息不丢失 2.RabbitMQ消息的重复消费问题 3.RabbitMQ延迟队列 4.RabbitMQ消息堆积 5.RabbitMQ高可用机制 三.Kafka 1.Kafka如何保证消息不丢失 2.Kafka如何保证消费消息的顺序性 3.Kafka高可用机制 4.Ka…

运维笔记之linux运维管理基础

课程链接 001_课程介绍_哔哩哔哩_bilibili 编辑器vi/vim 在 CentOS 上使用 Vim 编辑器时&#xff0c;可以进行更多操作&#xff0c;包括复制、粘贴、删除、查找等。以下是一些常用的 Vim 操作命令&#xff1a; 复制光标所在行&#xff1a;按下 yy 键。剪切光标所在行&#…

MongoDB聚合:$set

聚合$set阶段可以为文档添加新的字段。$set输出的文档包含输入文档中的所有现有字段和新添加的字段。$set是$addFields的别名&#xff0c;从MongoDB4.2开始支持。$set和$addFields等价于$project阶段&#xff0c;这两个阶段都等同于 $project 阶段&#xff0c;后者明确指定输入…

黑马程序员——javase基础——day05——面向对象基础

目录&#xff1a; 面向对象 面向对象介绍为什么要用面向对象编程面向对象.重点学习什么?类和对象 什么是类什么是对象对象的属性和行为类的定义对象的使用学生类的定义和使用对象内存图 Java内存分配单个对象多个对象思考&#xff1a;多个引用指向相同成员变量和局部变量的区…