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

相关推荐
一只栖枝1 小时前
华为 HCIE 大数据认证中 Linux 命令行的运用及价值
大数据·linux·运维·华为·华为认证·hcie·it
wuicer3 小时前
ubuntu 20.04 安装anaconda以及安装spyder
linux·运维·ubuntu
快乐的划水a4 小时前
组合模式及优化
c++·设计模式·组合模式
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任4 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
cui__OaO5 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
星星火柴9365 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头5 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
小晶晶京京5 小时前
day34-LNMP详解
linux·运维·服务器
画个太阳作晴天5 小时前
A12预装app
linux·服务器·前端