C语言访问Mysql

news2025/1/11 3:59:13

文章目录

  • C语言访问Mysql
    • 1. 环境设置
    • 2. mysql接口介绍
      • (1) 初始化mysql_init()
      • (2) 链接数据库mysql_real_connect
      • (3) 下发mysql命令mysql_query()
      • (4) 获取执行结果mysql_store_result
      • (5) 释放结果集mysql_free_result()
      • (6) 获取结果行数mysql_num_rows
      • (7) 获取结果列数mysql_num_fields
      • (8) 获取列名mysql_fetch_fields
      • (9) 获取结果内容mysql_fetch_row
      • (10) 关闭mysql链接mysql_close
    • 3. 测试代码

C语言访问Mysql

1. 环境设置

环境设置这里我就简单介绍一下,参考我mysql环境安装的博客:MySQL环境安装_Ryujianli的博客-CSDN博客

如果你像我一样在linux下安装了mysql,就能在对应的目录下找到库和头文件

ls /lib64/mysql
ls /usr/include/mysql

在这里插入图片描述

如果你找不到,可以再安装一下

yum install mysql-devel

配置好环境后,直接打开vscode开始测试,要#include<mysql/mysql.h>引入mysql的头文件

注意makefile文件的写法:

mytest:test.cc
	g++ -o mytest test.cc -L/lib64/mysql -lmysqlclient -std=c++11 
.PHONY:clean
clean:
	rm -f mytest

测试代码:

#include<iostream>
#include<mysql/mysql.h>

int main()
{
   std::cout<<"mysql client version: "<<mysql_get_client_info()<<std::endl;
   return 0;
}

如果上面代码能成功运行证明你的库引入成功

在这里插入图片描述

2. mysql接口介绍

(1) 初始化mysql_init()

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

MYSQL * mysql_init(MYSQL *mysql)

参数说明:  mysql设置为nullptr, 函数分配,初始化,并返回一个新的对象。
返回值:    成功返回一个MYSQL类型的对象, 失败返回nullptr

(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);
参数说明:
		mysql: 你创建并初始化好的MYSQL类型的对象, 即mysql_init的返回值
		host: 这里使用本地环回地址,"127.0.0.1"
		user: 代表数据库的使用者
        passwd: userd的密码
		db: 代表你要连接的数据库名称
        port: mysql服务的端口号, 默认是3306
        unix_socket: unix套接字, 设置为nullptr代表这里是网络通信   
		clientflag: 设置为0
返回值:
         成功返回连接成功的MYSQL对象, 失败返回nullptr

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

建立好链接之后,获取英文没有问题,如果获取中文是乱码:设置链接的默认字符集是utf8,原始默认是latin1

mysql_set_character_set(myfd, "utf8");

(3) 下发mysql命令mysql_query()

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

参数说明: 
		第一个参数上面已经介绍过
 		q: 代表你要执行的sql语句
返回值:
		成功返回0, 失败返回非0

(4) 获取执行结果mysql_store_result

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

MYSQL_RES *mysql_store_result(MYSQL *mysql);

MYSQL_RES的介绍:

  • 该函数会调用MYSQL变量中的st_mysql_methods中的 read_rows 函数指针来获取查询的结果

  • 。同时该函数会返回MYSQL_RES 这样一个变量,该变量主要用于保存查询的结果(调用mysql_store_result函数时是把存储的数据转储到MYSQL_RES中)。

  • 同时该函数malloc了一片内存空间来存储查询过来的数据,所以一定要使用mysql_free_result() 函数来释放,否则会造成内存泄漏。

  • 执行完mysql_store_result以后,其实数据都已经在MYSQL_RES变量中了。

在这里插入图片描述

MYSQL_RES叫做结果集,我们可以把想象成一个char**类型的,每一小块空间里存储的是一条记录中的某一个数据所以要用一个char *类型的指针去指向这一个数据,一行的数据就构成一条记录,一共有多少条记录就有多少行,每一行都会有一个二维指针去指向这一行

(5) 释放结果集mysql_free_result()

void mysql_free_result(MYSQL_RES *result)

(6) 获取结果行数mysql_num_rows

my_ulonglong mysql_num_rows(MYSQL_RES *res);

在这里插入图片描述

(7) 获取结果列数mysql_num_fields

unsigned int mysql_num_fields(MYSQL_RES *res);

(8) 获取列名mysql_fetch_fields

MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);

(9) 获取结果内容mysql_fetch_row

MYSQL_ROW其实是char **,可以当成一个二维数组来用

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);

在这里插入图片描述

(10) 关闭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);

3. 测试代码

前提:makefile文件的写法我在环境设置部分已经说明,在使用此代码测试前要为自己创建一个mysql下的普通账号并赋予其对特定数据库的所有权限,在我上一个博客中:

MySQL用户管理_Ryujianli的博客-CSDN博客

#include<iostream>
#include<mysql/mysql.h>
#include<string>

const std::string host="127.0.0.1";
const std::string user="user_l";
const std::string password="1003898";
const std::string db="conn";
const unsigned int port=3306;

int main()
{
    // std::cout<<"mysql client version: "<<mysql_get_client_info()<<std::endl;

    MYSQL* my=mysql_init(nullptr);
    if(nullptr ==my)
    {
        std::cerr<< "init MySQL error" <<std::endl;
        return 1;
    }

    if(mysql_real_connect(my,host.c_str(),user.c_str(),password.c_str(),db.c_str(),port,nullptr,0)==nullptr)
    {
        std::cerr<<"connect MySQL error"<<std::endl;
        return 2;
    }

    mysql_set_character_set(my,"utf8");

    // 增删改简单处理

    // std::string sql="insert into user (name,age,telephone) values ('张三', 19, '1523467')";
    // std::string sql="insert into user (name,age,telephone) values ('kitty', 29, '13234567')";
    // std::string sql="update user set name='Jimmy' where id=2";
    // std::string sql="delete from user where id=3";

    // 查的处理
    std::string sql="select * from user";

    int n=mysql_query(my,sql.c_str());
    if(n==0)
        std::cout<<sql<< " success " <<std::endl;
    else
    {
        std::cout<<sql<< " failed " <<std::endl;
        return 3;
    }

    MYSQL_RES*res=mysql_store_result(my);
    if(nullptr==res)
    {
        std::cerr<< "mysql_store_result error" <<std::endl;
        return 3;
    }

    // 全部都是和结果集有关的, res
    int rows=mysql_num_rows(res);
    int fields=mysql_num_fields(res);

    std::cout<< "行: "<<rows<<std::endl;
    std::cout<< "列: "<<fields<<std::endl;

    // 属性
    MYSQL_FIELD*fields_array=mysql_fetch_fields(res);
    for(int i=0;i<fields;++i)
    {
        std::cout<<fields_array[i].name<< "\t";
    }
    std::cout<< "\n";

    // 内容
    for(int i=0;i<rows;++i)
    {
        MYSQL_ROW row= mysql_fetch_row(res);    // char**
        for(int j=0;j<fields;++j)
        {
            std::cout<<row[j]<< "\t";    // *(row+j)
        }
        std::cout<< "\n";
    }  
    std::cout<<fields_array[0].db<<" "<<fields_array[0].table<<std::endl;

    // std::cout<<"connect success"<<std::endl;

    mysql_free_result(res);
    mysql_close(my);

    return 0;
}

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

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

相关文章

Java——》synchronized互斥性

推荐链接&#xff1a; 总结——》【Java】 总结——》【Mysql】 总结——》【Redis】 总结——》【Kafka】 总结——》【Spring】 总结——》【SpringBoot】 总结——》【MyBatis、MyBatis-Plus】 总结——》【Linux】 总结——》【MongoD…

Solidity 小白教程:13. 继承

Solidity 小白教程&#xff1a;13. 继承 这一讲&#xff0c;我们介绍solidity中的继承&#xff08;inheritance&#xff09;&#xff0c;包括简单继承&#xff0c;多重继承&#xff0c;以及修饰器&#xff08;modifier&#xff09;和构造函数&#xff08;constructor&#xff…

新手必看!Python爬虫 教程:IP池的使用

前言 嗨喽~大家好呀&#xff0c;这里是小曼呐 ❤ ~! 一、简介 爬虫中为什么需要使用代理 一些网站会有相应的反爬虫措施&#xff0c;例如很多网站会检测某一段时间某个IP的访问次数&#xff0c;如果访问频率太快以至于看起来不像正常访客&#xff0c;它可能就会禁止这个IP的访…

CE单相智能电力仪表ADL200

安科瑞 华楠 ADL200 单相电子式电能表主要用于计量低压网络的单相有功电能&#xff0c;同时可测量电压、电流、功率等电量&#xff0c; 并可选配 RS485 通讯功能&#xff0c;方便用户进行用电监测、集抄和管理。可灵活安装于配电箱内&#xff0c;实现对不同区域和不 同 负 荷 …

分布式系统第三讲:全局唯一ID实现方案

分布式系统第三讲&#xff1a;全局唯一ID实现方案 本文主要介绍常见的分布式ID生成方式&#xff0c;大致分类的话可以分为两类&#xff1a;一种是类DB型的&#xff0c;根据设置不同起始值和步长来实现趋势递增&#xff0c;需要考虑服务的容错性和可用性; 另一种是类snowflake型…

信息化发展34

IT 审计目的 1 、IT 审计的目的是指通过开展IT 审计工作&#xff0c; 了解组织IT 系统与IT 活动的总体状况&#xff0c; 对组织是否实现口目标进行审查和评价&#xff0c; 充分识别与评估相关口风险&#xff0c;提出评价意见及改进建议&#xff0c; 促进组织实现IT 目标。 2 、…

禁用或卸载没那么复杂!如何在Windows 11上禁用或删除McAfee

​当你从Microsoft以外的制造商处购买新的Windows设备时,该设备可能已安装McAfee防病毒软件。虽然在你的电脑上安装防病毒软件总是一个好主意,但你可能更喜欢与McAfee不同的程序。在这种情况下,了解如何卸载McAfee是很重要的。 另一方面,你可能对McAfee很满意,但需要暂时…

忽悠苹果,销量垫底?小屏iPhone已经落寞,iPhone13mini即将停产

苹果公司的小屏iPhone系列可能即将走到尽头。据彭博社报道&#xff0c;苹果最新发布的 iPhone 13 mini 库存已经见底&#xff0c;部分款式在美国官网发货时间显示为2-3周&#xff0c;甚至最久达到了6-8周。这种现象表明&#xff0c;在周二的发布活动结束后&#xff0c;苹果最后…

SpringBoot底层注解

文章目录 前言一、Configuration二、Import导入组件三、Conditional条件装配四、ImportResource导入Spring配置文件五、ConfigurationProperties配置绑定总结 前言 本文主要讲诉Configuration、Import、Conditional、ImportResource、ConfigurationProperties注解。 先将实体…

一心堂正式启动“心链-SRM”项目,携手企企通搭建引领发展的采购供应链协同平台

近日&#xff0c;中国药品连锁零售行业首家上市企业一心堂药业集团股份有限公司&#xff08;以下简称“一心堂”&#xff09;与企企通成功召开“心链-SRM”采购供应链管理项目启动会。双方高层领导及项目团队关键成员出席现场&#xff0c;各子公司管理团队通过视频会议形式参与…

双碳目标下基于“遥感+”集成技术的碳储量、碳排放、碳循环、温室气体等多领域监测与模拟实践

卫星遥感具有客观、连续、稳定、大范围、重复观测的优点&#xff0c;已成为监测全球碳盘查不可或缺的技术手段&#xff0c;卫星遥感也正在成为新一代 、国际认可的全球碳核查方法。目的就是梳理碳中和与碳达峰对卫星遥感的现实需求&#xff0c;系统总结遥感技术在生态系统碳储量…

利用VB宏设置将多个excel表合并为一个

多个excel合并成一个excel文件-应用哥科技 Sub MergeExcelFiles() 声明变量 Dim MyFile As Variant Dim MySheet As Worksheet, MySheet1 As Worksheet Dim LastRow As Long, LastRow1 As Long Dim NextRow As Long 设置初始值 NextRow 1 打开多个Excel文件 MyFile Applicati…

【算法】分治法的应用——快速排序

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; 给大家跳段街舞感谢支持&#xff01;ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ …

30岁+文转码程序媛求职路复盘:也算是逆袭了!

这篇文章来自一位群友的分享&#xff1a; 这篇文章写于下班路上&#xff0c;刚刚入职不久&#xff0c;我想再冲刺一下大厂&#xff0c;阳哥建议我坚持总结打卡&#xff0c;可以尝试写写博客。 那我就从这篇开始吧&#xff0c;希望开个好头&#xff01; 上班的感觉真好 今天是…

bim与数字孪生智能建造的关系

随着建筑业数字化改革的推进&#xff0c;我们正迈入数字孪生时代&#xff0c;而真正实现建筑物数字孪生的智能建造&#xff0c;其基础前提是建造对象和建造过程的高度数字化&#xff0c;这样一个过程唯有依托BIM建立数据模型才能实现&#xff0c;真正达到智能建造或智慧运维。 …

内网穿透的应用-如何搭建WordPress博客网站,并且发布至公网上?

文章目录 如何搭建WordPress博客网站&#xff0c;并且发布至公网上&#xff1f;概述前置准备1 安装数据库管理工具1.1 安装图形图数据库管理工具&#xff0c;SQL_Front 2 创建一个新数据库2.1 创建数据库2.2 为数据库创建一个用户 3 安装PHP7.44. 创建一个新站点4.1 创建站点根…

CUDA小白 - NPP(6) 图像处理 Geometry Transforms (1)

cuda小白 原始API链接 NPP GPU架构近些年也有不少的变化&#xff0c;具体的可以参考别的博主的介绍&#xff0c;都比较详细。还有一些cuda中的专有名词的含义&#xff0c;可以参考《详解CUDA的Context、Stream、Warp、SM、SP、Kernel、Block、Grid》 常见的NppStatus&#xf…

Win11自带微软输入法怎么输入π及其他希腊字母

如果用搜狗等第三方输入法的话就没有这些问题了&#xff0c;各种符号很方便。 自带的输入法输入 pi 和 pai 都不能正常输入 π \pi π 参考文章 https://www.cnblogs.com/qq-757617012/p/14078133.html 如果用自带的输入法可以采用以下方式 输入uuxl xl表示“希腊”&#x…

最长回文子串(Longest Palindromic substring)

什么叫回文串 就是正读和反读都是一样的字符串&#xff0c;比如aba,abba,cdc像这样的字符串都是回文字符串 暴力破解法来查找最长的回文子串 这个图解的意思就是我们要拿到每一个右边的数&#xff0c;然后与左边的数一一匹配 下面看一下java的实现代码 package com.pxx;/*** …

详细解析如何用“双指针“解题(面试必备,小白一看就会系类)

一、前言 大家在平时的训练和交流中肯定多少都会听过或者见过用"双指针"去快速的解题&#xff0c;那么大家有没有想过&#xff0c;为什么要用"双指针"呢&#xff1f;这里的"双指针"和我们平时了解的指针一样吗&#xff1f; 其实&#xff0c;这里…