Linux C++ 链接数据库并对数据库进行一些简单的操作

一.引言(写在之前)

在我们进行网络业务代码书写的时候,我们总是避免对产生的数据进行增删改查,为此,本小博主在这里简历分享一下自己在Linux中C++语言与数据之间交互的代码的入门介绍。

二.代码书写以及一些变量和函数的简单应用

1.头文件的引入

cpp 复制代码
#include <mysql/mysql.h>

包含了连接数据库的头文件和库文件

2.一些函数和变量的介绍

MYSQL 数据库链接句柄

mysql_init(MYSQL* mysql) 用来初始化数据库连接句柄,需要传入一个句柄并返回一个指向句柄的指针

mysql_real_connect(连接句柄,用户名,密码,数据库名称,端口(0表示默认端口,即3303),一般给NULL,一般也给NULL);

mysql_close(MYSQL*mysql);表示关闭连接

mysql_query(MYSQL *mysql,char* sql) 表示执行sql语句,char* sql即要执行的sql语句

MYSQL_RES *mysql_store_result(MYSQL *mysql);返回一个指向返回结果集的指针。

uint64_t mysql_num_rows(MYSQL_RES *res); 表示返回的数据个数即行数

unsigned int mysql_field_count(MYSQL *mysql);查看当前行数

三.附上我自己的测试代码吧(大家不可以照抄熬,数据库名字和表的结构不一样会导致大家出错,也可以call me maybe)

cpp 复制代码
#include <mysql/mysql.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
int main() {
  MYSQL mysql_con;

  MYSQL *mysql = mysql_init(&mysql_con);

  if (mysql == &mysql_con) {
    printf("hahahhahahah\n");
  }//打印此玩意,就证明mysql_init与mysql_con是一个玩意

  if (mysql == NULL) {
    printf("mysql init failed\n");
    exit(1);
  }//打印这行说明初始化失败,如果是自己写的代码的话。检查连接句柄是不是有问题或者是不是忘记初始化了

  mysql = mysql_real_connect(mysql, "localhost", "root", "wsx962464", "c220x",
                             3306, NULL, 0);//localhost可以换成127.0.0.1,这一行千万不可以照抄,数据库名字啥的都不一样
  if (mysql == NULL) {
    printf("连接失败\n");
    exit(1);
  }

  printf("连接成功\n");

  char *sql = "insert into student values(3,'zzj',55)";

  int quert_res = mysql_query(mysql, sql);

  if (quert_res == 0) {
    printf("执行成功\n");
    exit(1);
  } else {
    printf("执行失败\n");
  }

  mysql_close(mysql);

  return 0;
}

四.last but not least

最后在命令太进行编译的时候,千万千万不要忘记加库名如下:

最后加上-lmysqlclient(哪个标志挡住了,可能看不到)

相关推荐
IvorySQL34 分钟前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king3 小时前
入门 java 和 数据库
java·数据库·后端
jiayou647 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
Johny_Zhao18 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
NineData19 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
blasit1 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库