当前位置: 首页 > news >正文

【MySQL】使用C/C++连接MySQL数据库

【MySQL】使用C/C++连接MySQL数据库

  • 验证
  • 使用
  • select特殊点

本文目的:使用MySQL提供的CAPI完成对数据库的操作

验证

#include <iostream>
#include <mysql/mysql.h>int main()
{std::cout<<"mysql cilent version: "<<mysql_get_client_info()<<std::endl;return 0;
}

注意:使用mysqlclient库需要指明库的位置-L和库的名称-l

[wmh@pDaD Test]$ g++ test.cc -o  test -L/lib64/mysql -lmysqlclient
[wmh@pDaD Test]$ ./test
mysql cilent version: 5.7.42

使用

MySQL-5.7API接口介绍

#include <iostream>
#include <mysql/mysql.h>
#include <string>
#include <unistd.h>
const std::string host="127.0.0.1";
const std::string user = "connection";
const std::string passwd="123456";
const std::string db="scott";
const unsigned int port = 3306;
int main()
{MYSQL* mysql = mysql_init(nullptr);//初始化MySQL句柄if(nullptr == mysql){std::cerr<<"init MySQL error"<<std::endl;return 1;}if(mysql_real_connect(mysql,host.c_str(),user.c_str(),passwd.c_str(),db.c_str(),port,nullptr,0) == nullptr)//连接MySQL数据库{std::cerr<<"connect MySQL error"<<std::endl;return 2;}mysql_set_character_set(mysql,"utf8");//设置字符集编码std::string sql="update user set age='60' where id=3";int n = mysql_query(mysql,sql.c_str());//下发命令if(n==0) std::cout<<sql<<"success"<<std::endl;else std::cout<<sql<<"failed"<<std::endl;mysql_close(mysql);return 0;
}
mysql> select* from user;
+----+-----+-----------+
| id | age | name      |
+----+-----+-----------+
|  1 |  28 | 赵志敬    |
|  3 |  18 | 杨过      |
|  4 |  16 | 小龙女    |
+----+-----+-----------+mysql> select* from user;
+----+-----+-----------+
| id | age | name      |
+----+-----+-----------+
|  1 |  28 | 赵志敬    |
|  3 |  60 | 杨过      |
|  4 |  16 | 小龙女    |
+----+-----+-----------+

select特殊点

sql执行完以后,如果是查询语句,我们要能看到数据显示出来,那么就需要mysql_store_result这个函数来保存结果到本地

MYSQL_RES *mysql_store_result(MYSQL *mysql);

获取结果行数mysql_num_rows

my_ulonglong mysql_num_rows(MYSQL_RES *res);

获取结果列数mysql_num_fields

unsigned int mysql_num_fields(MYSQL_RES *res);

以列为单位获取列属性mysql_fetch_fields

MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);
typedef struct st_mysql_field {char *name;                 /* Name of column */char *org_name;             /* Original column name, if an alias */char *table;                /* Table of column if column was a field */char *org_table;            /* Org table name, if table was an alias */char *db;                   /* Database for table */char *catalog;	      /* Catalog for table */char *def;                  /* Default value (set by mysql_list_fields) */unsigned long length;       /* Width of column (create length) */unsigned long max_length;   /* Max width for selected set */unsigned int name_length;unsigned int org_name_length;unsigned int table_length;unsigned int org_table_length;unsigned int db_length;unsigned int catalog_length;unsigned int def_length;unsigned int flags;         /* Div flags */unsigned int decimals;      /* Number of decimals in field */unsigned int charsetnr;     /* Character set */enum enum_field_types type; /* Type of field. See mysql_com.h for types */void *extension;
} MYSQL_FIELD;

以行为单位获取结果内容mysql_fetch_row

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);

MYSQL_ROW其实就是char **.当成一个二维数组

释放结果集内存

void mysql_free_result(MYSQL_RES *result)

调用mysql_store_result返回结构体,这个函数malloc了一片内存空间来存储查询过来的数据,需要free掉

整体示例

#include <iostream>
#include <mysql/mysql.h>
#include <string>
#include <unistd.h>
const std::string host = "127.0.0.1";
const std::string user = "connection";
const std::string passwd = "123456";
const std::string db = "scott";
const unsigned int port = 3306;
int main()
{MYSQL *mysql = mysql_init(nullptr); // 初始化MySQL句柄if (nullptr == mysql){std::cerr << "init MySQL error" << std::endl;return 1;}if (mysql_real_connect(mysql, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), port, nullptr, 0) == nullptr) // 连接MySQL数据库{std::cerr << "connect MySQL error" << std::endl;return 2;}mysql_set_character_set(mysql, "utf8"); // 设置字符集编码// std::string sql="update user set age='60' where id=3";std::string sql = "select * from user";int n = mysql_query(mysql, sql.c_str()); // 下发命令if (n == 0)std::cout << sql << "success" << std::endl;elsestd::cout << sql << "failed" << std::endl;// 保存结果集转储到res中MYSQL_RES *res = mysql_store_result(mysql);if (res == nullptr){std::cerr << "mysql_store_result_error" << std::endl;}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 << std::endl;for (int i = 0; i < rows; i++){//row可以认为是一个char** 指针MYSQL_ROW row = mysql_fetch_row(res);//以行为单位获取记录for (int j = 0; j < fields; ++j){std::cout << row[j] << "\t";}std::cout << "\n";}std::cout << fields_array[0].db << " " << fields_array[0].table << std::endl;mysql_free_result(res);//释放结果集mysql_close(mysql);//关闭MYSQL句柄return 0;
}

在这里插入图片描述

http://www.lryc.cn/news/106946.html

相关文章:

  • 【Python】从同步到异步多核:测试桩性能优化,加速应用的开发和验证
  • 使用checkBox组件时,动态设置disabled,仍能触发click事件的原因及解决办法
  • 【JavaScript】如何进行除法运算且保留小数部分不参与四舍五入【推荐库bignumber.js 】
  • 掌握Java JDK 1.8 API帮助文档中文版,事半功倍编程
  • Spring Boot的自动配置原理
  • NFS服务器
  • 说明学习委员之作业管理系统—后端部分
  • 质数(判定质数 分解质因数 筛质数)
  • SAP数据库表维护视图生成器的使用
  • 数据结构 | 递归
  • 微信发视频怎么不压缩画质?试试这几招
  • 【网络安全带你练爬虫-100练】第16练:使用session发送请求
  • 论文代码学习—HiFi-GAN(3)——模型损失函数loss解析
  • CLion中avcodec_receive_frame()问题
  • Linux安装操作(Mac版本)
  • Linux(四)--包软件管理器与Linux上软件的下载示例
  • HTML <param> 标签
  • 基于ARM+FPGA (STM32+ Cyclone 4)的滚动轴承状态监测系统
  • 二、数据结构10:堆 模板题+算法模板(堆排序,模拟堆)
  • W6100-EVB-PICO做DNS Client进行域名解析
  • 【linux-网络】4层转发方法-iptable以及nginx
  • vue复制文案,复制图片,黏贴图片
  • Web应急思路
  • shell脚本清理redis模糊匹配的多个key,并计算释放内存大小
  • python-MySQL数据库建表语句(需要连接数据库)转存为Excel文档-工作小记
  • iOS Block介绍
  • 小程序安全性加固:如何保护用户数据和防止恶意攻击
  • Ubuntu的tar命令详解
  • 使用elementplus实现文本框的粘贴复制
  • 计算机毕设 深度学习卫星遥感图像检测与识别 -opencv python 目标检测