C语言:C语言实现对MySQL数据库表增删改查功能

基础DOME可以用于学习借鉴;

具体代码

javascript 复制代码
#include <stdio.h> 
#include <mysql.h> // mysql 文件,如果配置ok就可以直接包含这个文件

//宏定义 连接MySQL必要参数
#define SERVER "localhost" //或 127.0.0.1
#define USER "root"
#define PASSWORD "W113416w+" //password
#define DATABASE "domedata" //your_database
int main(void) {
	MYSQL mysql; //数据库句柄
	MYSQL_RES* res; //查询结果集 
	MYSQL_ROW row; //记录结构体

	//初始化数据库 
	mysql_init(&mysql);
	if (&mysql == NULL) {
		//fprintf(stderr, "%s\n", mysql_error(&mysql));
		exit(1);
	}

	//设置字符编码
	mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk");

	//连接数据库
	if (mysql_real_connect(&mysql, SERVER, "root",
		//"password", "database_name"分别填写自己的的数据库登录密码和表所在的数据库名称
		//这里替换成自己的的数据库等路密码和自己所建的数据库名称即可
		PASSWORD, DATABASE, 3306, NULL, 0) == NULL) {
		//fprintf(stderr, "%s\n", mysql_error(&mysql));
		mysql_close(&mysql);
		printf("错误原因: %s\n", mysql_error(&mysql));
		printf("连接失败!\n");
		exit(-1);
	}

	//查询数据
	int ret = mysql_query(&mysql, "select * from student;");
	//student是自己在数据库中所建的表名
	printf("ret: %d\n", ret);
	printf("第一次打印数据库 \n"); //打印
	//获取结果集
	res = mysql_store_result(&mysql);

	//给 ROW 赋值,判断 ROW 是否为空,不为空就打印数据。
	while (row = mysql_fetch_row(res)) {
		printf("%s ", row[0]); //打印 ID
		printf("%s ", row[1]); //打印姓名
		printf("%s ", row[2]); //打印班级
		printf("%s \n", row[3]);//打印性别
	}

	// 插入数据
	if (mysql_query(&mysql, "INSERT INTO student (id,name,age,grade,iphone) VALUES (2,'Alice', 20,92,'15555556666')")) {
		fprintf(stderr, "%s\n", mysql_error(&mysql));
		mysql_close(&mysql);
		exit(1);
	}
	printf("Inserted successfully.\n");

	// 查询数据
	printf("------插入数据后:------第二次打印数据库 \n"); //打印 
	ret = mysql_query(&mysql, "select * from student;");
	//student是自己在数据库中所建的表名
	printf("ret: %d\n", ret);

	//获取结果集
	res = mysql_store_result(&mysql);

	//给 ROW 赋值,判断 ROW 是否为空,不为空就打印数据。
	while (row = mysql_fetch_row(res)) {
		printf("%s ", row[0]); //打印 ID
		printf("%s ", row[1]); //打印姓名
		printf("%s ", row[2]); //打印班级
		printf("%s \n", row[3]);//打印性别
	}

	// 更新数据
	if (mysql_query(&mysql, "UPDATE student SET grade = 99 WHERE name = 'Alice'")) {
		//fprintf(stderr, "%s\n", mysql_error(&mysql));
		mysql_close(&mysql);
		exit(1);
	}
	printf("Updated successfully.\n");


	// 查询数据
	printf("------修改数据后:------第三次打印数据库 \n"); //打印 
	ret = mysql_query(&mysql, "select * from student;");
	//student是自己在数据库中所建的表名
	printf("ret: %d\n", ret);

	//获取结果集
	res = mysql_store_result(&mysql);

	//给 ROW 赋值,判断 ROW 是否为空,不为空就打印数据。
	while (row = mysql_fetch_row(res)) {
		printf("%s ", row[0]); //打印 ID
		printf("%s ", row[1]); //打印姓名
		printf("%s ", row[2]); //打印班级
		printf("%s \n", row[3]);//打印性别
	}

	// 删除数据
	if (mysql_query(&mysql, "DELETE FROM student WHERE name = 'Alice'")) {
		//fprintf(stderr, "%s\n", mysql_error(&mysql));
		mysql_close(&mysql);
		exit(1);
	}
	printf("Deleted successfully.\n");

	// 查询数据
	printf("------删除数据后:------第四次打印数据库 \n"); //打印 
	ret = mysql_query(&mysql, "select * from student;");
	//student是自己在数据库中所建的表名
	printf("ret: %d\n", ret);

	//获取结果集
	res = mysql_store_result(&mysql);

	//给 ROW 赋值,判断 ROW 是否为空,不为空就打印数据。
	while (row = mysql_fetch_row(res)) {
		printf("%s ", row[0]); //打印 ID
		printf("%s ", row[1]); //打印姓名
		printf("%s ", row[2]); //打印班级
		printf("%s \n", row[3]);//打印性别
	}

	//释放结果集 
	mysql_free_result(res);

	//关闭数据库
	mysql_close(&mysql);
	system("pause");
	return 0;
}

输出结果:

javascript 复制代码
ret: 0
第一次打印数据库
0 李四 21 98
1 王五 20 85
Inserted successfully.
------插入数据后:------第二次打印数据库
ret: 0
0 李四 21 98
1 王五 20 85
2 Alice 20 92
Updated successfully.
------修改数据后:------第三次打印数据库
ret: 0
0 李四 21 98
1 王五 20 85
2 Alice 20 99
Deleted successfully.
------删除数据后:------第四次打印数据库
ret: 0
0 李四 21 98
1 王五 20 85
请按任意键继续. . .

相关链接

  1. SQL:Windows下C/C++连接访问MySQL数据库(亲测有效!一遍过!)
相关推荐
HackTwoHub10 分钟前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
wuminyu15 分钟前
专家视角看Java字节码加载与存储指令机制
java·linux·c语言·jvm·c++
l1t16 分钟前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK24 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)1 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Navigator_Z1 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
S1998_1997111609•X2 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
iCxhust3 小时前
微机原理实践教程(C语言篇)---A001闪烁灯
c语言·开发语言·汇编·单片机·嵌入式硬件·51单片机·微机原理
KmSH8umpK3 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
爱编码的小八嘎3 小时前
C语言完美演绎9-9
c语言