C/C++链接数据库(MySQL)(超级详细)

 目录

 1.进入MySQL后,用mysql数据库 

1.1查看一看user表

​编辑1.2从user拿出来User和Host

1.3创建一个用户表,只允许本地(想要远端链接就把'localhost'改成'%')

1.4再查一下用户就有了(connector)

1.5测试一下能否登录上

1.6创建一个可以连接的数据库(在root创建的)

1.7但ljw这没法查看到,需要root给权限

1.8给权限再刷新一下

1.9ljw就可以show看到了

2.现在是localhost(本地连接),没法用Windows链接

3.访问数据库,安装C/C++可以访问MySQL的库

3.1开发环境

3.1.1下载头文件

3.1.2查看

3.1.3可以更改mysql端口号

4.在vscode上进行测试

4.1创建一个目录

4.2在vscode上打开并创建文件

4.3包含头文件

4.3.1简单的测试

5.mysql接口介绍

5.1官方文档

5.2介绍一下常用的几个接口

5.2.1初始化mysql_init()

5.2.2关闭数据库mysql_close

​编辑

5.2.3链接数据库mysql_real_connect

5.2.3.1建立好链接之后,获取英文没有问题,如果获取中文是乱码:

5.2.3.1.1mysql_set_character_set

5.2.4 查看链接失败

5.2.5查看链接状态

5.2.6 下发mysql命令mysql_query

5.2.7常规用法

5.3解决select

5.3.1获取执行结果mysql_store_result

5.3.2 表上数据的本质就是一个二维数组(行,列)

5.3.2.1获取结果行数mysql_num_rows

5.3.2.2获取结果列数mysql_num_fields

5.3.2.3 如同迭代器一般 获取结果内容mysql_fetch_row

5.3.3 获取列属性 mysql_fetch_fields

5.3.4 记得释放 mysql_free_result


1.进入MySQL后,用mysql数据库 

1.1查看一看user表

1.2从user拿出来User和Host

1.3创建一个用户表,只允许本地(想要远端链接就把'localhost'改成'%')

mysql> create user '自己取的名字'@'localhost' identified by '自己的密码';

1.4再查一下用户就有了(connector)

1.5测试一下能否登录上

1.6创建一个可以连接的数据库(在root创建的)

1.7但ljw这没法查看到,需要root给权限

1.8给权限再刷新一下

1.9ljw就可以show看到了

2.现在是localhost(本地连接),没法用Windows链接

3.访问数据库,安装C/C++可以访问MySQL的库

3.1开发环境

3.1.1下载头文件

如果没有下载:下载头文件;可以用这个命令下载一下:

sudo apt install libmysqlclient-dev

3.1.2查看

3.1.3可以更改mysql端口号(3306)

vim /etc//mysql//mysql.conf.d/mysqld.cnf

自己添加即可 

4.在vscode上进行测试

4.1创建一个目录

4.2在vscode上打开并创建文件

4.3包含头文件

#include <mysql/mysql.h>

4.3.1简单的测试

  • test.cc
  • 通过 mysql_get_client_info() 函数,来验证我们的引入是否成功
#include <iostream>
#include <mysql/mysql.h>int main() {printf("mysql client Version: %s\n", mysql_get_client_info());return 0;
}
  • makfile(记得加上 -lmysqlclient)
test:test.ccg++ -o $@ $^ -std=c++11 -lmysqlclient
.PHONY:clean
clean:rm -f test

5.mysql接口介绍

5.1官方文档

https://dev.mysql.com/doc/c-api/9.1/en/

5.2介绍一下常用的几个接口

要使用库,必须先进行初始化! 常用接口   mysqld是一套网络服务那么就注定了我们在进行mysql操作之前,一定是要能链接上mysql,所以要在之前创建一些基础的mysql数据结构。

5.2.1初始化mysql_init()

MySQL :: MySQL 8.0 C API Developer Guide :: 5.4.41 mysql_init()

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

5.2.2关闭数据库mysql_close

MySQL :: MySQL 5.7 C API Developer Guide :: 5.4.5 mysql_close()

5.2.3链接数据库mysql_real_connect

MySQL :: MySQL 8.0 C API Developer Guide :: 5.4.58 mysql_real_connect()

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

const string host = "localhost";
const string user = "ljw";
const string passwd = "ljw031126";
const string db = "jj";
const unsigned int port = 6666;
#include <iostream>
#include <string>
#include <mysql/mysql.h>using namespace std;const string host = "localhost";
const string user = "ljw";
const string passwd = "ljw031126";
const string db = "jj";
const unsigned int port = 6666;int main() 
{MYSQL* my = mysql_init(nullptr);if(my == nullptr){cerr<< "init MySQL error" <<endl;return 1;}if(mysql_real_connect(my, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), port, nullptr, 0) == nullptr){cerr<< "connect MYSQL error" <<endl;return 2;}//到这就链接成功了cout<< "success" <<endl;//关闭~mysql_close(my);return 0;
}

 测试:

5.2.3.1建立好链接之后,获取英文没有问题,如果获取中文是乱码:

设置链接的默认字符集是utf8,原始默认是latin1

5.2.3.1.1mysql_set_character_set

MySQL :: MySQL 5.7 C API 开发指南 :: 5.4.69 mysql_set_character_set()

mysql_set_character_set(myfd, "utf8");

5.2.4 查看链接失败

若关闭mysql服务就会连接失败

5.2.5查看链接状态

show processlist;

5.2.6 下发mysql命令mysql_query

MySQL :: MySQL 8.4 C API 开发指南 :: 5.4.57 mysql_query()

#include <iostream>
#include <string>
#include <mysql/mysql.h>
#include <unistd.h>using namespace std;const string host = "localhost";
const string user = "ljw";
const string passwd = "ljw031126";
const string db = "jj";
const unsigned int port = 6666;int main() 
{MYSQL* my = mysql_init(nullptr);if(my == nullptr){cerr<< "init MySQL error" <<endl;return 1;}if(mysql_real_connect(my, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), port, nullptr, 0) == nullptr){cerr<< "connect MYSQL error" <<endl;return 2;}string sql;while(true){cout<< "MYSQL>>>";if(!getline(cin, sql) || sql == "quit"){cout<< "bye bye" <<endl;break;}int n =mysql_query(my, sql.c_str());if(n == 0){cout<< sql << "success: " << n <<endl;}else{cerr<< sql << "faild" <<endl;}}//到这就链接成功了cout<< "success" <<endl;//关闭~mysql_close(my);return 0;
}

测试:

先创建个表,并给上权限

这里的;可以不用加 (这里测试时,没法直接back,要按住ctrl 和 back一起)

5.2.7常规用法

增删改是最简单的,只需要保证这个是成功的

这个select不行,没结果

5.3解决select

5.3.1获取执行结果mysql_store_result

MySQL :: MySQL 8.0 C API 开发指南 :: 5.4.84 mysql_store_result()

把结果转储到MYSQL_RES了(是为了更好的做二次处理)

5.3.2 表上数据的本质就是一个二维数组(行,列)

5.3.2.1获取结果行数mysql_num_rows
5.3.2.2获取结果列数mysql_num_fields

5.3.2.3 如同迭代器一般 获取结果内容mysql_fetch_row

这样的话结果就拿到了 

这样就可以打印出来了

5.3.3 获取列属性 mysql_fetch_fields

MySQL :: MySQL 5.7 C API Developer Guide :: 5.4.19 mysql_fetch_fields()

打印结果

很多内容属性都可以查

5.3.4 记得释放 mysql_free_result

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

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

相关文章

Jmeter中的定时器

4&#xff09;定时器 1--固定定时器 功能特点 固定延迟&#xff1a;在每个请求之间添加固定的延迟时间。精确控制&#xff1a;可以精确控制请求的发送频率。简单易用&#xff1a;配置简单&#xff0c;易于理解和使用。 配置步骤 添加固定定时器 右键点击需要添加定时器的请求…

msvcr100.dll丢失的解决方法,六种解决msvcr100.dll丢失的方法

在使用Windows操作系统的过程中&#xff0c;用户可能会遇到各种各样的问题&#xff0c;其中之一就是“msvcr100.dll丢失”的错误提示。这个问题通常出现在尝试运行某些软件或游戏时&#xff0c;由于缺少这个重要的动态链接库文件&#xff0c;导致程序无法正常启动。本文将详细介…

排序(Java数据结构)

1. 排序的概念及引用 1.1 排序的概念 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。(所有的排序都是默认从小到大排序) 稳定性&#xff1a;假定在待排序的记录序列中&#xff…

VH6501国产替代同星TH7011干扰仪?

文章目录 同星TH7011干扰仪VH6501有使用过TH7011的么,可以在评论区讨论一下~ 同星TH7011干扰仪 干货分享 | 一文详解同星CAN总线干扰仪的使用方法 VH6501

蓝桥杯每日真题 - 第23天

题目&#xff1a;&#xff08;直线&#xff09; 题目描述&#xff08;12届 C&C B组C题&#xff09; 解题思路&#xff1a; 题目理解: 在平面直角坐标系中&#xff0c;从给定的点集中确定唯一的直线。 两点确定一条直线&#xff0c;判断两条直线是否相同&#xff0c;可通过…

目录遍历漏洞-CVE-2021-41773

目录 简介 原理 例子 Apache路径穿越漏洞 环境搭建 漏洞原理 漏洞利用 简介 目录遍历漏洞&#xff08;也称为路径遍历漏洞&#xff09;是一种由于Web服务器或Web应用程序对用户输入的文件名称的安全性验证不足而导致的安全漏洞。 原理 目录遍历漏洞允许攻击者在未授权…

.NET9 - 新功能体验(三)

书接上回&#xff0c;我们继续来聊聊.NET9和C#13带来的新变化。 01、Linq新方法 CountBy 和 AggregateBy 引入了新的方法 CountBy 和 AggregateBy后&#xff0c;可以在不经过GroupBy 分配中间分组的情况下快速完成复杂的聚合操作&#xff0c;同时方法命名也非常直观&#xff0…

Android蓝牙架构,源文件目录/编译方式学习

Android 版本 发布时间 代号&#xff08;Codename&#xff09; Android 1.0 2008年9月23日 无 Android 1.1 2009年2月9日 Petit Four Android 1.5 2009年4月27日 Cupcake Android 1.6 2009年9月15日 Donut Android 2.0 2009年10月26日 Eclair Android 2.1 2…

YOLO-World解读:零基础学习开放世界模型

文章目录 一、摘要二、引言相关工作方法预训练公式模型架构可重新参数化的视觉-语言路径聚合网络&#xff08;RepVL-PAN&#xff09; 3.4 预训练方案 实验YOLO-World: 利用多样化数据集进行开放词汇对象检测的预训练方法YOLO-World: LVIS数据集上的零样本性能评估YOLO-World: 预…

信创改造 - TongRDS 安装方式之控制台安装【Window】

安装前准备 安装 jdk1.8 即可&#xff0c;并配上 环境变量 安装 1&#xff09;解压缩 2&#xff09;启动 进入安装路径的console\bin目录&#xff0c;在cmd命令行窗口运行console.bat 输入序号 1 如果想查看运行状态&#xff0c;可以重新执行 console.bat&#xff0c;然后输…

志愿者小程序源码社区网格志愿者服务小程序php

志愿者服务小程序源码开发方案&#xff1a;开发语言后端php&#xff0c;tp框架&#xff0c;前端是uniapp。 一 志愿者端-小程序&#xff1a; 申请成为志愿者&#xff0c;志愿者组织端进行审核。成为志愿者后&#xff0c;可以报名参加志愿者活动。 志愿者地图&#xff1a;可以…

Node.js的下载与安装(支持各种新旧版本)

目录 1、node官网 2、node软件下载 3、软件安装&#xff08;完整版&#xff09; 1、node官网 Node.js — Download Node.jshttps://nodejs.org/en/download/package-manager 2、node软件下载 按照下图进行选择node版本&#xff08;真心推荐16/18&#xff0c;而是尽量是LTS…

对于相对速度的重新理解 - 2

回到先前说的&#xff0c;先令真空光速为标准光速&#xff0c; 光子的绝对速度 范围&#xff0c; 物质粒子的 范围&#xff0c; 这样的话&#xff0c;我们就可以根据 和 &#xff0c;把速度分成3个段&#xff0c; 这样就可以出现速度和它的负值&#xff0c;也就是速度的矢量具…

大模型系列11-ray

大模型系列11-ray PlasmaPlasmaStore启动监听处理请求 ProcessMessagePlasmaCreateRequest请求PlasmaCreateRetryRequest请求PlasmaGetRequest请求PlasmaReleaseRequestPlasmaDeleteRequestPlasmaSealRequest ObjectLifecycleManagerGetObjectSealObject ObjectStoreRunnerPlas…

Java---反射机制

JAVA反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c; 都能够调用它的任意方法和属性&#xff1b;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。 在编译后产生…

Java 线程状态详解

1 引言 在 Java 多线程编程中&#xff0c;线程的状态是一个非常重要的概念。了解线程的状态及其转换过程&#xff0c;有助于我们更好地理解和控制线程的行为。本文将详细介绍 Java 线程的 6 种状态&#xff0c;并通过示例代码和图解来帮助读者更好地理解这些状态及其转换过程。…

AirScreen 安卓平板作为MacOS副屏

前言&#xff1a; 对笔记本续航有刚需&#xff0c;不得不选MacBook。 手机用的是mate40Pro&#xff0c;平板用的是matepad pro 12.6 干货&#xff1a; 参考网友的分享&#xff1a; https://www.bilibili.com/video/BV12A4y1d7zX/?spm_id_from333.337.search-card.all.click 【…

深度强化学习(RL)介绍

深度强化学习&#xff08;RL&#xff09;介绍 写到了一半&#xff0c;图待后补 一、强化学习概述 &#xff08;一&#xff09;与监督学习对比及定义 强化学习不同于监督学习&#xff0c;在一些任务中数据标注困难&#xff0c;但机器可通过环境反馈知道结果好坏。强化学习是机…

使用 Elasticsearch 构建食谱搜索(二)

这篇文章是之前的文章 “使用 Elasticsearch 构建食谱搜索&#xff08;一&#xff09;” 的续篇。在这篇文章中&#xff0c;我将详述如何使用本地 Elasticsearch 部署来完成对示例代码的运行。该项目演示了如何使用 Elastic 的 ELSER 实现语义搜索并将其结果与传统的词汇搜索进…

数据结构 【带环单链表】

在单链表中可能会存在一种情况&#xff0c;某一结点在经过几次转移之后回到了自己本身&#xff0c;这种情况就称之为带环链表。对于带环链表&#xff0c;我们不能轻易对其进行遍历&#xff0c;遍历可能会导致产生死循环。 带环链表的逻辑图如下所示&#xff1a;&#xff08;这…