C/C++连接MySQL

本章Gitee仓库地址:mysql连接基本操作

文章目录

    • 1. mysql connect库
    • 2. mysql相关接口
      • 2.1 mysql_init()
      • 2.2 mysql_real_connect()
      • 2.3 mysql_query()
      • 2.4 mysql_store_result()
        • 2.41 mysql_num_rows
        • 2.42 mysql_num_fields
        • 2.43 mysql_fetch_row
        • 2.44 mysql_fetch_fields
      • 2.5 mysql_free_result()

1. mysql connect库

使用C/C++连接MySQL,要先下载mysql的库

yum install -y mysql-community-server

在安装mysql的时候,就已经安装了

所需头文件:

ls /usr/include/mysql/

image-20240520192541293

动静态库:

ls /lib64/mysql/*

image-20240520192731764

如果没有,可以尝试安装

yum install mysql-devel

2. mysql相关接口

C语言API函数参考

2.1 mysql_init()

初始化mysql结构体对象

参数:

MYSQL *mysql_init(MYSQL *mysql)

2.2 mysql_real_connect()

连接mysql服务器

参数:

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 client_flag)

2.3 mysql_query()

参数:

int mysql_query(MYSQL *mysql,	//初始化的对象
                const char *stmt_str)	//sql语句(无需带';'或'/G')

image-20240520203926148

一般不会写这种客户端出来,这是直接将要执行的sql输入到程序

image-20240520204424983

这里增删改都没问题,只需保证成功即可,这里一定会成功,因为是事务。

select需要将一个个的数据显示出来,让用户获取,所以select还是需要获取上层的。

此外,如果需要显示中文,需要更改一下编码格式

image-20240520204806093

链接建立好之后,默认的latin1,要改成utf8

mysql_set_character_set(my, "utf8");

image-20240520205259766

2.4 mysql_store_result()

参数:

MYSQL_RES *mysql_store_result(MYSQL *mysql)

image-20240520205712093

查询结果以行为单位放在结果集当中

如何理解mysql_res

image-20240520210430979

这些+---+---+|分隔符都是格式化输出显示出来的,并不是在mysql真实存在的

真实存在的是右侧的那些内容,列属性、每列的数据(内容)

查出来的数据,是在内存当中,mysql将所有的数据,读取出来的时候都当作字符串

image-20240521000820959

可以理解为char **pptr[]或者char * ptr[][]

2.41 mysql_num_rows

语法:

my_ulonglong mysql_num_rows(MYSQL_RES *result)

提取有多少行

2.42 mysql_num_fields

语法:

unsigned int mysql_num_fields(MYSQL_RES *result)

提取有多少列

image-20240521001929881

2.43 mysql_fetch_row

语法:

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)

image-20240521002434546

对结果集进行操作,拿到其中的一行

类似与C++的迭代器

2.44 mysql_fetch_fields

语法:

MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *result)

获取表结构的属性

image-20240521003220136

MYSQL_RES *res = mysql_store_result(my);
    my_ulonglong rows = mysql_num_rows(res);
    my_ulonglong fields = mysql_num_fields(res);
    std::cout << "行:" << rows << std::endl;
    std::cout << "列:" << fields << std::endl;

    //属性
    MYSQL_FIELD *field_array = mysql_fetch_field(res);
    for(int i = 0; i < fields; i++)
    {
        //格式化输出
        std::cout << std::left << std::setw(15) << field_array[i].name << "\t";
    }
    std::cout << std::endl;

    //内容(数据)
    for(int i = 0; i < rows; i++)
    {
        MYSQL_ROW row = mysql_fetch_row(res);
        for(int j = 0; j < fields; j++)
        {
            std::cout << std::left << std::setw(15) << row[j] << "\t";
        }    
        std::cout << std::endl;
    }

image-20240521003905963

2.5 mysql_free_result()

提取的内容存在内存当中,系统给我们malloc好了,用完需要我们自己释放

void mysql_free_result(MYSQL_RES *result)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

openLayers加载wms图层并定位到该图层

openLayers定位到wms图层 我们的wms是加载geoserver发布的服务&#xff0c;wms加载的图层是没法通过layer.getSource().getExtent()来获取到extents&#xff08;边界&#xff09;的&#xff1b;实现思路是通过postgis的函数(st_extent(geom))来获取extents; 返回前端后格式化一…

WWW24因果论文(3/8) |通过因果干预实现图分布外泛化

【摘要】由于图神经网络 (GNN) 通常会随着分布变化而出现性能下降&#xff0c;因此分布外 (OOD) 泛化在图学习中引起了越来越多的关注。挑战在于&#xff0c;图上的分布变化涉及节点之间错综复杂的互连&#xff0c;并且数据中通常不存在环境标签。在本文中&#xff0c;我们采用…

C#电子名片(vCard)

目录 1.介绍 2.基本定义 3.字段信息 4&#xff0c;字段详解。 4.1&#xff0c;预定义类型的用法 4.2&#xff0c;基本类型 4.3&#xff0c;通讯地址类型 4.4&#xff0c;电信通信类型 4.5&#xff0c;地理类型 4.6&#xff0c;解释类型 5&#xff0c;应用。 6&…

Rviz 复选框插件

Rviz 复选框插件 0.引言1.实现效果 0.引言 参考1参考2参考3参考4 我想做的插件是类似于 pangolin 侧面的复选框&#xff0c;动态传递 bool 值给程序内部使用。查了一下只能是通过插件的方式进行实现。但是Display 的参数在编译阶段就写死了&#xff0c;我想要在运行期给定参数…

DreamPose: Fashion Image-to-Video Synthesis via Stable Diffusion

UW&UCB&Google&NVIDIA ICCV23https://github.com/johannakarras/DreamPose?tabreadme-ov-file 问题引入 输入参考图片 x 0 x_0 x0​和pose序列 { p 1 , ⋯ , p N } \{p_1,\cdots,p_N\} {p1​,⋯,pN​}&#xff0c;输出对应视频 { x 1 ′ , ⋯ , x N ′ } \{x_1,…

失落的方舟台服注册接收不到验证码 注册怎么验证手机号教程

《失落的方舟》&#xff08;Lost Ark&#xff09;是一款引人入胜的大型多人在线角色扮演游戏&#xff08;MMORPG&#xff09;&#xff0c;由韩国知名游戏开发商Smilegate精心打造。这款游戏凭借其绚丽的视觉效果、错综复杂的故事情节、媲美动作游戏的战斗机制以及无边无际的探索…

【OCPP】ocpp1.6协议第3.13章节SmartCharging介绍及翻译

目录 3.13 SmartCharging智能充电-概述 智能充电的目标 关键功能 消息类型 负载管理 动态电量配置 总结 3.13 SmartCharging智能充电-译文 3.13.1 Charging Profile Purpose充电配置的目的 3.13.2 Stacking charging profile堆叠充电配置 3.13.3 Combining charging profile pu…

为什么要学习c++?

你可能在想&#xff0c;“C&#xff1f;那不是上个时代的产物吗&#xff1f;” 哎呀&#xff0c;可别小看了这位“老将”&#xff0c;它在21世纪的科技舞台上依旧光芒万丈&#xff0c;是许多尖端技术不可或缺的基石&#xff01; 1. 无可替代 c源于c语言&#xff0c;它贴近于硬…

C++面向对象程序设计 - 标准输出流

在C中&#xff0c;标准输出流通常指的是与标准输出设备&#xff08;通常是终端或控制台&#xff09;相关联的流对象。这个流对象在C标准库中被定义为std::cout、std::err、std::clog&#xff0c;它们是std::ostream类的一个实例。 一、cout&#xff0c;cerr和clog流 ostream类…

去除uni微信小程序button的边框

想要去除button的边框&#xff0c;如下未去除边框时&#xff0c;非常影响观感。 解决方法 使用伪元素::after&#xff0c;简单但是易忘&#xff0c;正常情况下,我直接是给button上加上一个类名直接设置border&#xff1a;none&#xff0c;但是这样是无效的&#xff0c;应该如下…

【软考】下篇 第13章 层次式架构设计理论与实践

目录 一、概述1.2 通用分层1.2 分层架构注意点 二、表现层(展示层)2.1 表现层设计模式&#xff08;MVC、MVP、MVVM&#xff09;2.2 使用XML设计表现层2.3 UIP2.4 表现层动态生成设计思想 三、中间层(业务层、业务逻辑层)3.1 组件设计3.2 工作流设计3.3 实体设计3.4 业务逻辑层框…

CC1310 Debug interface is locked

XDS110连接CC1310板子&#xff0c;打开Smart RF 弹出窗口如下&#xff1a; 解决办法&#xff1a; 1 打开SmartRF Flash Programmer 2 选择连接的设备CC1310, 弹出如下窗口&#xff0c;点击OK。 3 点击Tools图标&#xff0c;选择CC26XX/CC13XX Forced Mass Erase。 4 在弹出的…

分布式锁的三种实现方案

目录 为什么需要分布式锁实现一个分布式锁需要考虑的点如何实现一个分布式锁基于数据库的实现基于 zookeeper 实现基于 redis 实现 实际项目中好用的轮子 为什么需要分布式锁 传统的 jdk 锁&#xff0c;比如 synchronized, reentrantlock 只能在单机环境中使用分布式场景下&am…

5.26 基于UDP的网络聊天室

需求&#xff1a; 如果有人发送消息&#xff0c;其他用户可以收到这个人的群聊信息 如果有人下线&#xff0c;其他用户可以收到这个人的下线信息 服务器可以发送系统信息实现模型 模型&#xff1a; 代码&#xff1a; //chatser.c -- 服务器端实现 #include <stdio.h>…

FastAPI - 组织模块2

FastAPI没有强制指定某种格式来组织项目结构&#xff0c;开发者可以根据自己喜好和项目需要来定制自己的项目结构。 https://fastapi.tiangolo.com/zh/tutorial/bigger-applications/ 在项目根目录创建python包routers&#xff0c;然后创建member.py文件 member.py文件内容 …

互联网应用主流框架整合之AOP

SpringAOP基本概念和约定流程 在实际的开发中有些内容并不是面向对象能够解决的&#xff0c;比如数据库事务&#xff0c;对于企业级应用非常重要&#xff0c;比如在电商系统中订单模块和交易模块&#xff0c;一边是交易记录一边是账户数据&#xff0c;就需要对这两者有统一的事…

权限维持--linux

隐藏文件/夹&-开头文件 如何创建: 在文件名之前加.即可 touch .1.s 如何清除、查找&#xff1a; ls -al rm -fr -文件 已-开头的文件直接读取是不行的需要带目录 隐藏时间戳 ①用其他文件的时间 touch -r zww.php testq.txt 如何清除、查看&#xff1a; stat test…

大模型基础知识

文章目录 1. 位置编码1.1 绝对位置编码1.2 相对位置编码1.3 旋转位置编码2. 注意力机制2.1 MHA(muti head attention)2.2 MQA(muti query attention)2.3 GQA(grouped query attention)3. 大模型分类4. 微调方法4.1 Prompt Tuning4.2 Prefix Tuning4.3 Lora4.4 QLora5. La…

探索机器人智能设备:开启智慧生活新篇章

机器人智能设备作为科技创新的代表&#xff0c;正以其独特的魅力吸引着越来越多的关注。它们不仅具备高度的智能化和自主化能力&#xff0c;还能在各种场景下发挥出强大的功能。 机器人智能设备的张总说&#xff1a;在智能家居领域&#xff0c;机器人智能设备可以帮助我们实现家…

改进rust代码的35种具体方法-类型(十九)-避免使用反射

上一篇文章 从其他语言来到Rust的程序员通常习惯于将反思作为工具箱中的工具。他们可能会浪费很多时间试图在Rust中实现基于反射的设计&#xff0c;却发现他们所尝试的事情只能做得不好&#xff0c;如果有的话。这个项目希望通过描述Rust在反思方面做什么和不做什么&#xff0c…