当前位置: 首页 > news >正文

【MySQL】使用C语言连接数据库

       看到标题,可能会疑惑,我们学习的不是C++吗,为什么使用C语言去连接数据库呢??实际上,这两种语言都可以连接数据库,但是C语言提供的API没有进行封装,更有利于我们学习数据库连接。面向API编程,哈哈哈哈哈哈!!!!!

一、安装适合自己平台的mysql connect库

       因为我使用的是Ubuntu,所以在这里就只介绍在Ubuntu中如何下载mysql connect库。在Ubuntu下载这个库还是比较简单的,只有几个指令执行就可以了。

更新包信息

sudo apt update

安装 MySQL 服务器

sudo apt install mysql-server

在Ubuntu中,MySQL的头文件和库文件通常位于以下位置:

  • 头文件(如mysql.h):/usr/include/mysql/
  • 库文件/usr/lib/x86_64-linux-gnu/(或者/usr/lib/,具体路径可能根据系统架构而异)

如果你需要这些文件,可以通过安装libmysqlclient-dev包来获得它们:

sudo apt install libmysqlclient-dev

这会将头文件和库文件安装到系统的标准位置。

       为了检查我们是否已经安装成功,我们可以使用mysql_get_client_info()函数尝试连接mysql client。注意在连接之前,确保自己的服务器是打开状态。

#include <iostream>
#include <string>
#include <mysql/mysql.h>int main()
{std::cout << "mysql client Version: " << mysql_get_client_info() << std::endl;return 0;
}
// Makefile写法
connect : connect.cc g++ -o $@ $^ -lmysqlclient -std=c++11.PHONY:clean
cleam: rm -f connect

二、mysql接口介绍

2.1 mysql_init()  初始化函数

       如果想要使用数据库,我们需要先进行初始化!创建出数据库句柄,之后的函数调用需要使用它!!

函数原型:

MYSQL *mysql_init(MYSQL *mysql);

代码示例: 

MYSQL *mfp = mysql_init(nullptr); // 大型结构体
if (mfp == nullptr)
{std::cerr << "init mysql error" << std::endl;return -1;
}

2.2 mysql_real_connect()  链接数据库

       在数据库初始化完毕之后,我们必须先连接数据库,在进行后续操作。(mysql网络部分是基于TCP/IP的)

函数原型:

MYSQL *mysql_real_connect(MYSQL *mysql, const char *host,const char *user,const char *passwd,const char *db,unsigned int port,const char *unix_socket,unsigned long clientflag);

参数说明:

  1. *MYSQL mysql:指向一个已初始化的 MYSQL 结构体的指针,通常使用 mysql_init() 初始化。

  2. *const char host:数据库服务器的主机名或 IP 地址,通常为 "localhost" 或者指定的服务器地址。

  3. *const char user:用于连接的 MySQL 用户名。

  4. *const char passwd:对应用户的密码。

  5. *const char db:要连接的数据库名。如果不需要选择特定数据库,可以传递 NULL

  6. unsigned int port:数据库服务器的端口号,默认为 3306。如果使用 Unix socket,通常可以设置为 0。

  7. *const char unix_socket:如果使用 Unix socket,可以提供 socket 文件的路径;如果使用 TCP/IP,则可以设置为 NULL

  8. unsigned long client_flag:连接选项的标志位,通常可以设置为 0。

       第一个参数MySQL是C API中一个非常重要的变量(mysql_init的返回值),里面的内存非常丰富,有port,dbname,charset等连接基本参数,他也包含了一个叫做st_mysql_methods的结构体变量,该变量里面保存着很多函数指针,这些函数指针将会在数据库连接成功以后的各种数据操作中被调用。

代码示例:

const std::string host = "127.0.0.1";
const std::string user = "connector";
const std::string passwd = "Hh.123456";
const std::string db = "test";
const unsigned int port = 3306;if (mysql_real_connect(mfp, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), 3306, nullptr, 0) == nullptr)
{return 2;
}
std::cout << "connect mysql success" << std::endl;

       建立好连接之后,获取英文没有问题,如果获取的中文是乱码,我们可以想到的是字符集没有设置正确,设置连接的默认字符集是utf8,原始默认是latinl

mysql_set_character_set(myfd, "utf8");

2.3 mysql_query()  下发mysl命令

函数原型:

int mysql_query(MYSQL *mysql, const char *q);

       第一个参数上面已经介绍过了,第二个参数要执行的sql语句,比如“select * from table”。

2.4 mysql_store_result()  获取执行结果

       sql执行完以后,如果是查询语句,我们当然还有读取数据,如果update,insert等语句,那么只用看操作成功与否即可。我们来看一看如何获取查询结果的:如果mysql_query返回成功,那么我们就通过mysql_store_result这个函数来读取结果。

函数原型:

MYSQL_RES *mysql_store_result(MYSQL *mysql);

       该函数会调用MySQL变量中的st_mysql_methods中的read_rows函数指针来获取查询的结果。 同时该函数会返回MYSQL_RES这样的变量,该变量主要用于保存查询结果。同时该函数malloc一片内存空间来存储查询过来的数据,所以我们一定要记住free(result),不然会造成内存泄露的,但是在MYSQL中会直接提供  void mysql_free_result(MYSQL_RES *result)    来进行释放空间。执行完mysql_store_result函数以后,其实数据都已经子啊MYSQL_RES变量中。

2.5 mysql_num_row()  获取结果行数

my_ulonglong mysql_num_rows(MYSQL_RES *res);

2.6 mysql_num_fields()  获取结果列数

unsigned int mysql_num_fields(MYSQL_RES *res);

2.7 mysql_fetch_fields()  获取列名

函数原型:

MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);

代码示例: 

int fields = mysql_num_fields(res);
MYSQL_FIELD *field = mysql_fetch_fields(res);
int i = 0;
for(; i < fields; i++){cout<<field[i].name<<" ";
}
cout<<endl;

2.8 mysql_fetch_row()  获取结果内容

函数原型:

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);

       这个函数会返回一个MYSQL_ROW变量,MYSQL_ROW其实就是一个char **,可以将其当成一个二维数组来使用。   

i = 0;
MYSQL_ROW line;
for(; i < nums; i++){line = mysql_fetch_row(res);  // 每一次调用都会自己刷新,并指向下一行int j = 0;for(; j < fields; j++){cout<<line[j]<<" ";}cout<<endl;
}

2.9 mysql_close()  关闭mysql链接

void mysql_close(MYSQL *sock);

2.10 mysql_free_result()  释放mysql空间

       在 MySQL C API 中,mysql_free_result() 函数用于释放与 MYSQL_RES 结构体相关的内存。当你完成对查询结果的处理后,调用此函数可以避免内存泄漏。

函数原型:

void mysql_free_result(MYSQL_RES *result);

参数:

  • result:指向要释放的 MYSQL_RES 结构体的指针。

使用示例:

MYSQL_RES *result = mysql_store_result(conn); // 处理结果...
mysql_free_result(result); // 释放内存

       在每次使用 mysql_store_result() 或类似函数后,都应该调用 mysql_free_result() 来清理资源。

相关文章:

【MySQL】使用C语言连接数据库

看到标题&#xff0c;可能会疑惑&#xff0c;我们学习的不是C吗&#xff0c;为什么使用C语言去连接数据库呢??实际上&#xff0c;这两种语言都可以连接数据库&#xff0c;但是C语言提供的API没有进行封装&#xff0c;更有利于我们学习数据库连接。面向API编程&#xff0c;哈哈…...

Vue学习记录之四(watch侦听器和watchEffect高级侦听器)

watch watch 用于侦听特定的响应式数据源&#xff08;如数据、计算属性等&#xff09;&#xff0c;比如ref或者是reactive时&#xff0c;并在其变化时执行回调函数。它适合用于处理副作用&#xff0c;如 API 请求或异步操作。使用 watch 适合特定数据变化的侦听&#xff0c;提…...

RedisTemplate操作ZSet的API

文章目录 ⛄概述⛄常见命令有⛄RedisTemplate API❄️❄️ 向集合中插入元素&#xff0c;并设置分数❄️❄️向集合中插入多个元素,并设置分数❄️❄️按照排名先后(从小到大)打印指定区间内的元素, -1为打印全部❄️❄️获得指定元素的分数❄️❄️返回集合内的成员个数❄️❄…...

Android 15 正式发布至 AOSP

Google官方宣布&#xff0c;将于近期发布了 Android 15&#xff0c;而在早些时候&#xff0c;Google已经将其源代码推送至 Android 开源项目 (AOSP)。未来几周内&#xff0c;Android 15 将在受支持的 Pixel 设备上正式推出&#xff0c;并将于今年晚些时候在三星、Honor、iQOO、…...

IEEE Electronic Library(IEL)数据库文献检索下载介绍及个人获取IEEE文献途径

一、数据库介绍 IEEE&#xff08;The Institute of Electrical and Electronics Engineers&#xff0c;电气电子工程师学会&#xff09;是目前全球最大的非营利性专业技术学会&#xff0c;在全球160多个国家拥有超过45万名会员。IEEE在电气电子、计算机、半导体、通讯、电力能…...

动手学习RAG:大模型重排模型 bge-reranker-v2-gemma微调

动手学习RAG: 向量模型动手学习RAG: moka-ai/m3e 模型微调deepspeed与对比学习动手学习RAG&#xff1a;rerank模型微调实践 bge-reranker-v2-m3动手学习RAG&#xff1a;迟交互模型colbert微调实践 bge-m3动手学习RAG: 大模型向量模型微调 intfloat/e5-mistral-7b-instruct动手学…...

蓝桥杯2024省C

P10898 [蓝桥杯 2024 省 C] 拼正方形 题目描述 小蓝正在玩拼图游戏&#xff0c;他有 7385137888721个 22的方块和 10470245 个 11 的方块&#xff0c;他需要从中挑出一些来拼出一个正方形&#xff0c;比如用 3 个 22 和 4 个 11 的方块可以拼出一个 44 的正方形&#xff0c;用…...

C++:内部类,匿名对象,操作符new与delete

一.内部类 1.如果一个类定义在另一个类的内部&#xff0c;这个内部类就叫做内部类。内部类是一个独立的类&#xff0c;跟定义在全局相比&#xff0c;他只是受外部类类域限制和访问限定符限制&#xff0c;所以外部类定义的对象中不包含内部类。 2.内部类默认是外部类的友元类。…...

【数据结构】排序算法---计数排序

文章目录 1. 定义2. 算法步骤3. 动图演示4. 性质5. 算法分析6. 代码实现C语言PythonJavaGo 结语 1. 定义 计数排序又称为鸽巢原理&#xff0c;是对哈希直接定址法的变形应用。计数排序不是基于比较的排序算法&#xff0c;其核心在于将输入的数据值转化为键存储在额外开辟的数组…...

mysql时间日期函数、获取当前日期和时间、日期和时间格式化、提取日期部分、日期和时间的算术操作、其他日期函数、日期和时间的比较、日期字符串转换

获取当前日期和时间 NOW()&#xff1a;返回当前的日期和时间。CURDATE()&#xff1a;返回当前的日期。CURTIME()&#xff1a;返回当前的时间。 SELECT NOW(), CURDATE(), CURTIME(); 日期和时间格式化 DATE_FORMAT(date, format)&#xff1a;根据指定的格式字符串格式化日期…...

Android开发高频面试题之——kotlin篇

Android开发高频面试题之——kotlin篇 Android开发高频面试题之——Java基础篇 Android开发高频面试题之——Kotlin基础篇 Android开发高频面试题之——Android基础篇 1. Kotlin如何实现空安全的? Kotlin 将变量划分为可空和不可空,通过查看字节码可知,声明不可空的变量会…...

8--SpringBoot原理分析、注解-详解(面试高频提问点)

目录 SpringBootApplication 1.元注解 --->元注解 Target Retention Documented Inherited 2.SpringBootConfiguration Configuration Component Indexed 3.EnableAutoConfiguration&#xff08;自动配置核心注解&#xff09; 4.ComponentScan Conditional Co…...

语言的枚举

不同语言的枚举 C/C枚举本质是整型&#xff0c;在Java中是对象&#xff0c;而非基本类型&#xff0c;可通过instanceof Object判断是否是对象类型。C#与Java不同&#xff0c;枚举是值类型。C语言更纯粹&#xff0c;枚举绝对当成整数&#xff0c;可以对枚举变量用整数赋值&…...

C# Redis 框架开发技术详解

引言 Redis 是一个高性能的键值存储系统&#xff0c;广泛用于缓存、消息队列和实时分析等场景。在 C# 中&#xff0c;有几个著名的库和框架可以方便地与 Redis 进行交互。以下是几个常用的 C# Redis 库&#xff1a; StackExchange.Redis: 这是目前最流行、最推荐的 C# Redis 客…...

Rust:Result 和 Error

在 Rust 编程语言中&#xff0c;错误处理是一个核心部分&#xff0c;用于确保程序的健売性和可靠性。Rust 通过 Result 枚举和 Error 特质&#xff08;trait&#xff09;来处理错误。 Result 枚举 Result 是一个泛型枚举&#xff0c;用于表示一个操作可能成功或失败。它有两个…...

Python基础(八)——MySql数据库

一.数据库 【库——>表——>数据】 借助数据库对数据进行组织存储&#xff0c;借助SQL语言对数据库、数据进行操作管理 Mysql数据库 下载&#xff1a;https://www.mysql.com/ 查看是否安装配置成功&#xff1a; 安装DBeaver用于Mysql数据库图形化 安装&#xff1a;…...

统一网关--gateway(仅供自己参考)

1、网关的概念&#xff1a; 2、网关的功能&#xff1a; &#xff08;1&#xff09;&#xff1a;身份认证和权限校验 &#xff08;2&#xff09;&#xff1a;服务路由&#xff08;具体的业务路由到具体的服务&#xff09;&#xff0c;负载均衡&#xff08;多台服务的话&#xff…...

【Leetcode152】分割回文串(回溯 | 递归)

文章目录 一、题目二、思路三、代码 一、题目 二、思路 具体例子和步骤&#xff1a;假设 s "aab"&#xff0c;步骤如下&#xff1a; 初始状态&#xff1a; s "aab"path []res [] 第一层递归&#xff08;外层循环&#xff09;&#xff1a; path []检…...

基于BiGRU+Attention实现风力涡轮机发电量多变量时序预测(PyTorch版)

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域&#xff0c;讨论了各种复杂的深度神经网络思想&#xff0c;如卷积神经网络、循环神经网络、生成对…...

深入探究 Flask 的应用和请求上下文

目标 读完本文后&#xff0c;您应该能够解释&#xff1a; 什么是上下文哪些数据同时存储在应用程序和请求上下文中在 Flask 中处理请求时&#xff0c;处理应用程序和请求上下文所需的步骤如何使用应用程序和请求上下文的代理如何在视图函数中使用current_app和代理request什么…...

大型活动交通拥堵治理的视觉算法应用

大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动&#xff08;如演唱会、马拉松赛事、高考中考等&#xff09;期间&#xff0c;城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例&#xff0c;暖城商圈曾因观众集中离场导致周边…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南

精益数据分析&#xff08;97/126&#xff09;&#xff1a;邮件营销与用户参与度的关键指标优化指南 在数字化营销时代&#xff0c;邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天&#xff0c;我们将深入解析邮件打开率、网站可用性、页面参与时…...

Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下&#xff0c;风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...

【Nginx】使用 Nginx+Lua 实现基于 IP 的访问频率限制

使用 NginxLua 实现基于 IP 的访问频率限制 在高并发场景下&#xff0c;限制某个 IP 的访问频率是非常重要的&#xff0c;可以有效防止恶意攻击或错误配置导致的服务宕机。以下是一个详细的实现方案&#xff0c;使用 Nginx 和 Lua 脚本结合 Redis 来实现基于 IP 的访问频率限制…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?

在工业自动化持续演进的今天&#xff0c;通信网络的角色正变得愈发关键。 2025年6月6日&#xff0c;为期三天的华南国际工业博览会在深圳国际会展中心&#xff08;宝安&#xff09;圆满落幕。作为国内工业通信领域的技术型企业&#xff0c;光路科技&#xff08;Fiberroad&…...

学习一下用鸿蒙​​DevEco Studio HarmonyOS5实现百度地图

在鸿蒙&#xff08;HarmonyOS5&#xff09;中集成百度地图&#xff0c;可以通过以下步骤和技术方案实现。结合鸿蒙的分布式能力和百度地图的API&#xff0c;可以构建跨设备的定位、导航和地图展示功能。 ​​1. 鸿蒙环境准备​​ ​​开发工具​​&#xff1a;下载安装 ​​De…...

ui框架-文件列表展示

ui框架-文件列表展示 介绍 UI框架的文件列表展示组件&#xff0c;可以展示文件夹&#xff0c;支持列表展示和图标展示模式。组件提供了丰富的功能和可配置选项&#xff0c;适用于文件管理、文件上传等场景。 功能特性 支持列表模式和网格模式的切换展示支持文件和文件夹的层…...

shell脚本质数判断

shell脚本质数判断 shell输入一个正整数,判断是否为质数(素数&#xff09;shell求1-100内的质数shell求给定数组输出其中的质数 shell输入一个正整数,判断是否为质数(素数&#xff09; 思路&#xff1a; 1:1 2:1 2 3:1 2 3 4:1 2 3 4 5:1 2 3 4 5-------> 3:2 4:2 3 5:2 3…...

深度解析云存储:概念、架构与应用实践

在数据爆炸式增长的时代&#xff0c;传统本地存储因容量限制、管理复杂等问题&#xff0c;已难以满足企业和个人的需求。云存储凭借灵活扩展、便捷访问等特性&#xff0c;成为数据存储领域的主流解决方案。从个人照片备份到企业核心数据管理&#xff0c;云存储正重塑数据存储与…...