MySQL 使用C语言链接

news/2024/9/17 2:33:41/ 标签: mysql, c语言, adb

mysql的基础,我们之前已经学过,后面我们只关心使用
要使用C语言连接mysql,需要使用mysql官网提供的库,大家可以去官网下载
我们使用C接口库来进行连接
要正确使用,我们需要做一些准备工作:

  • 保证mysql服务有效
  • 在官网上下载合适自己平台的mysql connect库,以备后用

各种函数的使用也可以看官方手册

文章目录

  • Connector/C 使用
  • mysql接口介绍
      • 初始化 —— mysql_init()
      • 链接数据库 —— mysql_real_connect
      • 参数 MYSQL
      • 下发mysql命令 —— mysql_query
      • 获取执行结果 —— mysql_store_result
    • 读取
      • 获取结果行数 —— mysql_num_rows
      • 获取结果列数 —— mysql_num_fields
      • 获取列名 —— mysql_fetch_fields
      • 获取结果内容 —— mysql_fetch_row
      • 关闭mysql链接 —— mysql_close

Connector/C 使用

我们下下来的库格式如下:

[hb@MiWiFi-R1CL-srv lib]$ tree .
.
├── include
│ 		├── big_endian.h
│ 		├── byte_order_generic.h
│ 		├── byte_order_generic_x86.h
│ 		├── decimal.h
│ 		├── errmsg.h
│		├── keycache.h
│		├── little_endian.h
│ 		├── m_ctype.h
│ 		├── m_string.h
│	    ├── my_alloc.h
│	    ├── my_byteorder.h
│ 		├── my_compiler.h
│		├── my_config.h
│	    ├── my_dbug.h
│ 		├── my_dir.h
│	    ├── my_getopt.h
│	    ├── my_global.h
│	    ├── my_list.h
│	    ├── my_pthread.h
│	    ├── mysql
│ 		│ 	├── client_authentication.h
│	    │ 	├── client_plugin.h
│ 	    │ 	├── client_plugin.h.pp
│ 	    │	├── get_password.h
│	    │ 	├── plugin_auth_common.h
│ 	    │	├── plugin_trace.h
│	    │	├── psi
│	    │   │   ├── mysql_file.h
│	    │   │   ├── mysql_idle.h
│	    │   │   ├── mysql_mdl.h
│ 	    │   │   ├── mysql_memory.h
│	    │   │   ├── mysql_ps.h
│ 	    │   │   ├── mysql_socket.h
│	    │   │   ├── mysql_sp.h
│	    │   │   ├── mysql_stage.h
│	    │   │   ├── mysql_statement.h
│	    │   │   ├── mysql_table.h
│	    │   │   ├── mysql_thread.h
│ 	    │   │   ├── mysql_transaction.h
│ 	    │   │   ├── psi_base.h
│	    │   │   ├── psi.h
│	    │   │   └── psi_memory.h
│	    │   ├── service_my_snprintf.h
│	    │   └── service_mysql_alloc.h
│ 	    ├── mysql_com.h
│	    ├── mysql_com_server.h
│ 	    ├── mysqld_ername.h
│	    ├── mysqld_error.h
│ 	    ├── mysql_embed.h
│	    ├── mysql.h
│ 	    ├── mysql_time.h
│ 	    ├── mysql_version.h
│ 	    ├── my_sys.h
│ 	    ├── my_xml.h
│ 	    ├── sql_common.h
│	    ├── sql_state.h
│	    ├── sslopt-case.h
│ 	    ├── sslopt-longopts.h
│	    ├── sslopt-vars.h
│ 	    └── typelib.h
└── lib├── libmysqlclient.a├── libmysqlclient_r.a -> libmysqlclient.a├── libmysqlclient_r.so -> libmysqlclient.so├── libmysqlclient_r.so.18 -> libmysqlclient.so.18├── libmysqlclient_r.so.18.3.0 -> libmysqlclient.so.18.3.0├── libmysqlclient.so -> libmysqlclient.so.18├── libmysqlclient.so.18 -> libmysqlclient.so.18.3.0└── libmysqlclient.so.18.3.0

其中 include 包含所有的方法声明, lib 包含所有的方法实现(打包成库)

尝试链接mysql client

mysql_get_client_info_96">mysql_get_client_info()

通过 mysql_get_client_info() 函数,来验证我们的引入是否成功

#include <stdio.h>
#include <mysql.h>int main()
{printf("mysql client Version: %s\n", mysql_get_client_info());return 0;
}[hb@MiWiFi-R1CL-srv lib]$ gcc -o test test.c -I./include -L./lib -lmysqlclient
[hb@MiWiFi-R1CL-srv lib]$ ls
include lib test test.c[hb@MiWiFi-R1CL-srv lib]$ ./test
./test: error while loading shared libraries: libmysqlclient.so.18: cannot open
shared object file: No such file or directory[hb@MiWiFi-R1CL-srv lib]$ export LD_LIBRARY_PATH=./lib #动态库查找路径
[hb@MiWiFi-R1CL-srv lib]$ ./test
mysql client Version: 6.1.6

mysql_125">mysql接口介绍

mysql_init_127">初始化 —— mysql_init()

要使用库,必须先进行初始化!

MYSQL *mysql_init(MYSQL *mysql);

MYSQL *mfp = mysql_init(NULL)

mysql_real_connect_135">链接数据库 —— 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);//建立好链接之后,获取英文没有问题,如果获取中文是乱码:
//设置链接的默认字符集是utf8,原始默认是latin1
mysql_set_character_set(myfd, "utf8");

参数 MYSQL

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

mysql_real_connect函数中各参数,基本都是顾名思意。

mysql__mysql_query_161">下发mysql命令 —— mysql_query

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

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

mysql_store_result_169">获取执行结果 —— 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_store_result以后,其实数据都已经在MYSQL_RES 变量中了,下面的api基本就是读取MYSQL_RES 中的数据。

mysql_num_rows_186">获取结果行数 —— mysql_num_rows

my_ulonglong mysql_num_rows(MYSQL_RES *res);

mysql_num_fields_191">获取结果列数 —— mysql_num_fields

unsigned int mysql_num_fields(MYSQL_RES *res);

mysql_fetch_fields_195">获取列名 —— 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;

mysql_fetch_row_210">获取结果内容 —— 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;
}

执行示例:
在这里插入图片描述

mysql__mysql_close_231">关闭mysql链接 —— mysql_close

void mysql_close(MYSQL *sock);

另外,mysql C api还支持事务等常用操作:
my_bool STDCALL mysql_autocommit(MYSQL * mysql, my_bool auto_mode);
my_bool STDCALL mysql_commit(MYSQL * mysql);
my_bool STDCALL mysql_rollback(MYSQL * mysql);


http://www.ppmy.cn/news/1521452.html

相关文章

MySQL灾难恢复策略:构建稳健的备份与恢复机制

在现代企业环境中&#xff0c;数据的安全性和可靠性至关重要。灾难恢复计划&#xff08;Disaster Recovery Plan, DRP&#xff09;是确保在发生灾难性事件后&#xff0c;能够迅速恢复业务的关键策略。对于依赖MySQL数据库的系统&#xff0c;实现有效的灾难恢复计划尤为重要。本…

信也科技基于 Apache SeaTunnel金融场景的应用实践探索

前言 作者&#xff1a;朱俊&#xff0c;信也科技&#xff0c;数据开发专家 离线开发一直是数据仓库建设中重要的一个环节。信也科技之前基于Azkaban构建了离线任务调度与开发平台&#xff0c;承载了公司90%以上的离线任务调度需求&#xff0c;以及玄策变量平台的每日变量跑批产…

lvs DR模式调试

DS配置&#xff1a; # cat /etc/keepalived_docker/keepalived.conf ! Configuration File for keepalived global_defs {router_id LVS_70 # 设置lvs的id&#xff0c;在一个网络内应该是唯一的 }vrrp_instance VI_70 {state MASTER # 两个 DS&#xff0…

网关,DNS,MAC地址,子网掩码,网段分别是什么?

网关、DNS、MAC地址、子网掩码和网段是计算机网络中的基础概念&#xff0c;它们在网络通信和数据交换中扮演着关键角色。以下将详细解释每个概念及其功能&#xff1a; 网关 定义&#xff1a;网关&#xff08;Gateway&#xff09;又称网间连接器或协议转换器&#xff0c;是用于…

vue3+ts封装类似于微信消息的组件

组件代码如下&#xff1a; <template><div:class"[voice-message, { sent: isSent, received: !isSent }]":style"{ backgroundColor: backgroundColor }"click"togglePlayback"><!-- isSent为false在左侧&#xff0c;为true在右…

【数据结构与算法 | 每日一题力扣篇】

1. 力扣3174&#xff1a;清楚数字 1.1 题目&#xff1a; 给你一个字符串 s 。 你的任务是重复以下操作删除 所有 数字字符&#xff1a; 删除 第一个数字字符 以及它左边 最近 的 非数字 字符。 请你返回删除所有数字字符以后剩下的字符串。 示例 1&#xff1a; 输入&…

Azure AI Search 中的二进制量化:优化存储和加快搜索速度

随着组织继续利用生成式 AI 的强大功能来构建检索增强生成 (RAG) 应用程序和代理&#xff0c;对高效、高性能和可扩展解决方案的需求从未如此强烈。 今天&#xff0c;我们很高兴推出二进制量化&#xff0c;这项新功能可将向量大小减少高达 96%&#xff0c;同时将搜索延迟减少高…

模板:测试计划文档

测试计划文档是软件测试过程中的一个重要组成部分&#xff0c;它详细描述了测试的范围、目标、方法、资源、时间表以及预期的测试结果等关键信息。一个完善的测试计划文档有助于确保测试活动的有序进行&#xff0c;提高测试效率和质量。以下是一个测试计划文档的基本框架和内容…

IMU助力JAXA空间站机器人

近日&#xff0c;日本宇宙航空研究开发机构&#xff08;JAXA&#xff09;宣布&#xff0c;在国际空间站&#xff08;ISS&#xff09;实验舱“希望号”&#xff08;Kibo&#xff09;上部署的一款移动摄像机器人将采用Epson M-G370系列惯性测量单元&#xff08;IMU&#xff09;。…

OpenCV结构分析与形状描述符(7)计算轮廓的面积的函数contourArea()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算轮廓的面积。 该函数计算轮廓的面积。与 moments 类似&#xff0c;面积是使用格林公式计算的。因此&#xff0c;返回的面积与你使用 drawCo…

PWR电源控制(低功耗模式)

1 PWR简介 1 程序后面是空循环&#xff0c;即使不用也会耗电&#xff0c;所以有了低功耗&#xff08;例如遥控器&#xff09; 2 也要保留唤醒模式&#xff0c;如串口接收数据中断唤醒&#xff0c;外部中断唤醒&#xff0c;RTC闹钟唤醒&#xff0c;在需要工作是&#xff0c;ST…

【机器学习】决策树与随机森林:模型对比与应用案例分析

文章目录 一.引言 在现代数据科学的世界中&#xff0c;决策树和随机森林是两个非常重要且广泛使用的机器学习算法。它们不仅因其高效性和强大的表现力而受到青睐&#xff0c;而且在解决实际问题时也表现出了令人印象深刻的能力。本篇文章将深入探讨这两个算法&#xff0c;帮助读…

前端登录鉴权——以若依Ruoyi前后端分离项目为例解读

权限模型 Ruoyi框架学习——权限管理_若依框架权限-CSDN博客 用户-角色-菜单&#xff08;User-Role-Menu&#xff09;模型是一种常用于权限管理的设计模式&#xff0c;用于实现系统中的用户权限控制。该模型主要包含以下几个要素&#xff1a; 用户&#xff08;User&#xff09;…

【Python】BeautifulSoup:HTML解析

BeautifulSoup 是 Python 中用于解析和处理 HTML 或 XML 文档的强大库。它提供了简洁的接口&#xff0c;能高效处理复杂的网页结构&#xff0c;非常适合网页爬虫和数据提取任务。本文将详细介绍如何使用 BeautifulSoup 进行 HTML 文档的解析与操作。 BeautifulSoup 对象 Beaut…

Go 语言知识点总结

在 Go 语言中&#xff0c;... 是用于定义可变参数&#xff08;variadic parameters&#xff09;的符号。 在 func sum(nums ...int) 中&#xff0c;nums ...int 表示函数 sum 可以接受任意数量的 int 类型的参数&#xff0c;传入的参数将被打包成一个切片 nums&#xff0c;将 …

硬件工程师笔试面试知识器件篇——电感

目录​​​​​​​ 3、电感 3.1、基础 电感原理图 电感实物图 3.1.1、定义与单位 1)定义: 2) 单位: 3.1.2、物理原理 1)法拉第电磁感应定律: 2)楞次定律: 3.1.3、电感器的构造 3.1.4、类型 3.1.5、应用 3.1.6、特性 3.1.7、设计考虑 3.2、相关问题 3.…

基于FCM模糊聚类算法的图像分割matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 FCM算法原理 4.2 图像分割中的应用 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a 3.部分核心程序 &#xff08;完整版代码包…

【嵌入式学习笔记】---- 通信基础

1 数据传输方式 按照数据传输的方式&#xff0c;通信可以分为串行通信和并行通信两大类1.1 串行通信 少量数据信号线&#xff08;8根以下&#xff09;&#xff0c;数据分成一位一位的逐个依次传输 1.2 并行通信 多根数据信号线&#xff08;8根以上&#xff09;&#xff0c…

【Kubernetes知识点问答题】健康检查

目录 1. Kubernetes 对集群 Pod 和容器健康状态如何进行监控和检测的。 2. 解释 LivenessProbes 探针的作用及其适用场景。 3. 解释 ReadinessProbe 探针的作用及其适用场景。 4. 解释 StartupProbe 探针的作用及其适用场景。 5. 说明 K8s 中 Pod 级别的 Graceful Shutdown…

Rust 赋能前端:PDF 分页/关键词标注/转图片/抽取文本/抽取图片/翻转...

❝ 我从不幻想成功。我只会为了成功努力实践 大家好&#xff0c;我是柒八九。一个专注于前端开发技术/Rust及AI应用知识分享的Coder ❝ 此篇文章所涉及到的技术有 WebAssembly Mupdf Pdf操作( 分页展示/文本抽离/文本标注/获取超链接/Pdf转图片/翻转/截取) 因为&#xff0c;行文…