mysql_init和mysql_real_connect的形象化认识

解析总结

在这里插入图片描述

1. mysql_init 的作用

mysql_init 用于初始化一个 MYSQL 结构体,为后续数据库连接和操作做准备。该结构体存储连接配置及状态信息,是 MySQL C API 的核心句柄。
示例:

MYSQL *conn = mysql_init(NULL); // 初始化连接句柄

2. mysql_real_connect 的参数

函数原型:

MYSQL *mysql_real_connect(MYSQL *mysql,           // 由 mysql_init 初始化的连接句柄const char *host,       // 服务器地址(如 "localhost" 或 IP)const char *user,       // 用户名(如 "root")const char *passwd,     // 密码const char *db,         // 默认数据库名(可选)unsigned int port,      // 端口号(默认 3306,若为 0 则使用默认值)const char *unix_socket,// Unix Socket 路径(通常为 NULL)unsigned long client_flag // 客户端标志(如 CLIENT_MULTI_STATEMENTS)
);

参数对照表

图片中的参数实际参数名说明
serverhost服务器地址
portport端口号(若为 0,使用默认值 3306)
unix_socketunix_socketUnix Socket 路径(通常填 NULL)
useruser用户名
passwordpasswd密码
databasedb默认连接的数据库(可选)
client_flagclient_flag客户端选项(如是否允许多语句查询)

3. 连接示例
MYSQL *conn = mysql_init(NULL);
if (!conn) {fprintf(stderr, "初始化失败\n");return;
}// 连接数据库
if (!mysql_real_connect(conn,                   // 句柄"localhost",            // 服务器地址"root",                 // 用户名"password123",          // 密码"mydb",                 // 默认数据库0,                      // 端口(0 表示默认 3306)NULL,                   // Unix Socket(NULL 表示默认)CLIENT_MULTI_STATEMENTS // 客户端标志
)) {fprintf(stderr, "连接失败: %s\n", mysql_error(conn));mysql_close(conn);return;
}

4. 数据库与表的操作

连接成功后,可通过其他 API 函数操作数据库和表:

  • 切换数据库mysql_select_db(conn, "database2");
  • 执行查询mysql_query(conn, "SELECT * FROM table1");
  • 处理结果集:使用 mysql_store_resultmysql_use_result

5. 注意事项
  • 参数顺序mysql_real_connect 的参数顺序固定,需严格遵循。
  • 端口与 Socketportunix_socket 一般不同时使用(若使用 Socket,端口填 0)。
  • 资源释放:连接结束后需调用 mysql_close(conn) 释放资源。

通过以上步骤,即可完成 MySQL 数据库的连接与基础操作。

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

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

相关文章

qt-QtQuick笔记之常见项目类简要介绍

qt-QtQuick笔记之常见项目类简要介绍 code review! 文章目录 qt-QtQuick笔记之常见项目类简要介绍1.QQuickItem2.QQuickRectangle3.QQuickImage4.QQuickText5.QQuickBorderImage6.QQuickTextInput7.QQuickButton8.QQuickSwitch9.QQuickListView10.QQuickGridView11.QQuickPopu…

0 基础学运维:解锁 K8s 云计算运维工程师成长密码

前言:作为一个过来人,我曾站在技术的门槛之外,连电脑运行内存和内存空间都傻傻分不清,完完全全的零基础。但如今,我已成长为一名资深的k8s云计算运维工程师。回顾这段历程,我深知踏上这条技术之路的艰辛与不…

Spring Boot - 数据库集成06 - 集成ElasticSearch

Spring boot 集成 ElasticSearch 文章目录 Spring boot 集成 ElasticSearch一:前置工作1:项目搭建和依赖导入2:客户端连接相关构建3:实体类相关注解配置说明 二:客户端client相关操作说明1:检索流程1.1&…

联想拯救者R720笔记本外接显示屏方法,显示屏是2K屏27英寸

晚上23点10分前下单,第二天上午显示屏送到,检查外包装没拆封过。这个屏幕左下方有几个按键,按一按就开屏幕、按一按就关闭屏幕,按一按方便节省时间,也支持阅读等模式。 显示屏是 :AOC 27英寸 2K高清 100Hz…

设计转换Apache Hive的HQL语句为Snowflake SQL语句的Python程序方法

首先,根据以下各类HQL语句的基本实例和官方文档记录的这些命令语句各种参数设置,得到各种HQL语句的完整实例,然后在Snowflake的官方文档找到它们对应的Snowflake SQL语句,建立起对应的关系表。在这个过程中要注意HQL语句和Snowfla…

什么是线性化PDF?

线性化PDF是一种特殊的PDF文件组织方式。 总体而言,PDF是一种极为优雅且设计精良的格式。PDF由大量PDF对象构成,这些对象用于创建页面。相关信息存储在一棵二叉树中,该二叉树同时记录文件中每个对象的位置。因此,打开文件时只需加…

Java基础知识总结(三十二)--API--- java.lang.Runtime

类中没有构造方法,不能创建对象。 但是有非静态方法。说明该类中应该定义好了对象,并可以通过一个static方法获取这个对象。用这个对象来调用非静态方法。这个方法就是 static Runtime getRuntime(); 这个Runtime其实使用单例设计模式进行设计。 class …

向量和矩阵算法笔记

向量和矩阵算法笔记 Ps:因为本人实力有限,有一部分可能不太详细,若有补充评论区回复,QWQ 向量 向量的定义 首先,因为我刚刚学到高中的向量,对向量的看法呢就是一条有长度和方向的线,不过这在数学上的定义其实是不对,甚至跟我看的差别其实有点大,真正的定义就是数域…

你的连接不是专用连接

当你打开网站看到如下提示,说明SSL证书到期了。 攻击者可能试图www窃取你的信息(例如、密码、消息或信用卡)。详细了解此警告 NET::ERR_CERT_DATE_INVALID 此服务器无法证明它是WWW ;它的安全证书已于2天前到期。这可能是错误配置或攻击者…

deb安装失败后,无法再安装别的包的解决方案

把package_name换成出安装问题的包 移除该包的安装标记 sudo dpkg --remove --force-remove-reinstreq package_name清理残留文件和配置 sudo apt-get purge package_name

51单片机开发:定时器中断

目标:利用定时器中断,每隔1s开启/熄灭LED1灯。 外部中断结构图如下图所示,要使用定时器中断T0,须开启TE0、ET0。: 系统中断号如下图所示:定时器0的中断号为1。 定时器0的工作方式1原理图如下图所示&#x…

变量声明是否可以放在语句之后?变量声明?声明变量一定需要指定类型吗?函数范围快捷使用临时变量?

变量声明是否可以放在语句之后? 除了C89必须将变量声明放在语句之前,其他主流编程语言基本都支持变量声明和语句混合使用。Fortran/C89/Pascal 只能将变量声明放在语句之前。 准确的说,Pascal的变量声明必须放在程序的说明定义部分,即程序首…

【电工基础】1.电能来源,触电伤害,触电预防,触电急救

一。电能来源 1.电能来源 发电-》输电-》变电-》配电 2.分配电 一类负荷 如果供电中断会造成生命危险,造成国民经济的重大损失,损坏生产的重要设备以致使生产长期不能恢复或产生大量废品,破坏复杂的工艺过程,以及破坏大…

简易计算器(c++ 实现)

前言 本文将用 c 实现一个终端计算器: 能进行加减乘除、取余乘方运算读取命令行输入,输出计算结果当输入表达式存在语法错误时,报告错误,但程序应能继续运行当输出 ‘q’ 时,退出计算器 【简单演示】 【源码位置】…

python-leetcode-从前序与中序遍历序列构造二叉树

105. 从前序与中序遍历序列构造二叉树 - 力扣(LeetCode) # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right r…

YOLOv11-ultralytics-8.3.67部分代码阅读笔记-head.py

head.py ultralytics\nn\modules\head.py 目录 head.py 1.所需的库和模块 2.class Detect(nn.Module): 3.class Segment(Detect): 4.class OBB(Detect): 5.class Pose(Detect): 6.class Classify(nn.Module): 7.class WorldDetect(Detect): 8.class RTDETRDec…

知识推理简要介绍

知识推理(Knowledge Reasoning)是人工智能(AI)、认知科学和逻辑学的核心领域,其本质是通过对已有知识的逻辑化处理与规则化推导,生成新的知识或结论。它不仅是机器智能的基石,也是人类认知能力的核心体现。 一、知识推理的定义与本质 定义 知识推理是通过形式化逻辑规则…

NLP深度学习 DAY4:Word2Vec详解:两种模式(CBOW与Skip-gram)

用稀疏向量表示文本,即所谓的词袋模型在 NLP 有着悠久的历史。正如上文中介绍的,早在 2001年就开始使用密集向量表示词或词嵌入。Mikolov等人在2013年提出的创新技术是通过去除隐藏层,逼近目标,进而使这些单词嵌入的训练更加高效。…

vscode+WSL2(ubuntu22.04)+pytorch+conda+cuda+cudnn安装系列

最近在家过年闲的没事,于是研究起深度学习开发工具链的配置和安装,之前欲与天公试比高,尝试在win上用vscodecuda11.6vs2019的cl编译器搭建cuda c编程环境,最后惨败,沦为笑柄,痛定思痛,这次直接和…

深入了解 npm 和 pnpm:前端包管理工具的选择与比较

在现代前端开发中,包管理工具已经成为了必不可少的组成部分。它们帮助我们管理项目的依赖、自动化任务、以及在团队协作时确保一致的开发环境。最常见的前端包管理工具有 npm 和 pnpm,它们各自具有独特的特点和优势。今天,我们就来一起深入了…