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

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

一.引言(写在之前)

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

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

        1.头文件的引入

#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)

#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(哪个标志挡住了,可能看不到)

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

相关文章:

  • Linux进程间通信--msgsnd函数的作用
  • P1629 邮递员送信(最短路)(内附封面)
  • 网络安全--原型链污染
  • Harbor企业镜像仓库部署
  • 【AI】《动手学-深度学习-PyTorch版》笔记(十一):分类问题-softmax回归
  • 【排序算法略解】(十种排序的稳定性,时间复杂度以及实现思想)(含代码)(完工于2023.8.3)
  • 学编程实用网站
  • Camunda 7.x 系列【5】 员工请假流程模型
  • 【C++从0到王者】第十七站:手把手教你写一个stack和queue及deque的底层原理
  • ffmpeg.c源码与函数关系分析
  • GD32F103待机模式与唤醒
  • 【Linux初阶】基础IO - 动静态库 | 初识、生成、链接、加载
  • 为Git仓库设置签名信息
  • iOS开发Swift开发UI页面链式调用库推荐
  • ClickHouse SQL与引擎--基本使用(一)
  • 2023-08-07力扣今日七题-好题
  • 支持多用户协同的思维导图TeamMapper
  • 【Vue】Parsing error: No Babel config file detected for ... vue
  • 2023-08-07力扣今日五题
  • ETHERCAT转PROFIBUS连接到300plc的配置方法
  • Spring Boot配置文件与日志文件
  • 可解释性分析的一些类别(草稿)(视觉)
  • HTTPS-RSA握手
  • bigemap国土管理行业应用
  • 深入探索 Splashtop Enterprise 的潜力
  • 创建型模式-单例模式
  • 2. Linux安装Git
  • 检查网站是HTTP那种协议与获取域名的ipv6地址
  • 【转】金融行业JR/T0197-2020《金融数据安全 数据安全分级指南》解读
  • FPGA学习——电子时钟模拟(新)