Ubuntu下如何C语言程序连接MYSQL 8.0(全教程)

1、 安装GCC(略)

2、 安装mysql(本人使用的是最新MySQL 8.0版本)

sudo apt install mysql-client

修改密码的教程请参考:https://blog.csdn.net/u013277209/article/details/108237466

(注意用ALTER 命令来改密码!)

(如果要允许远程访问,update user set host=’%’ where user=’root’)

3、 安装libmysqlclient-dev

sudo apt install libmysqlclient-dev

(这个会自动下载最新版本的连接库,不要加上任何数字!)

4、 如果上一步安装成功,你会在/usr/include/mysql中看到mysql.h,说明安装成功.

5、 直接include <mysql/mysql.h>即可引用

注意编译时:gcc -o mysqlTest $(mysql_config --cflags) mysqlTest.c $(mysql_config --libs)

一定要加上这几个config的参数,否则会编译失败

6、我的样例程序(有参考网络上的代码:Linux下使用C语言访问MySQL数据库(三):访问实现代码_麒麒川的博客-CSDN博客),经过测试可以正常打印数据库的内容

#include <mysql/mysql.h>
//注意:apt install libmysqlclient-dev即可
#include <stdio.h>
#include <stdlib.h> MYSQL *conn_ptr;
MYSQL_RES *res_ptr;
MYSQL_ROW sqlrow;
unsigned int timeout = 7; //超时时间7秒 void dispaly_row(MYSQL *ptr)
{
unsigned int field_count = 0;
while (field_count < mysql_field_count(ptr)) //返回在结果结合中字段的数目
{
printf("%s", sqlrow[field_count]);
field_count++;
}
printf("\n");
} void display_header()
{
MYSQL_FIELD *field_ptr;
printf("Column details:\n");
while ((field_ptr = mysql_fetch_field(res_ptr)) != NULL) //返回列的定义字段信息
{
printf("\t Name:%s\n", field_ptr->name);
printf("\t Type:");
if (IS_NUM(field_ptr->type)) //若字段类型为数字
{
printf("Numeric field\n");
}
else
{
switch (field_ptr->type)
{
case FIELD_TYPE_VAR_STRING:
printf("VACHAR\n");
break;
case FIELD_TYPE_LONG:
printf("LONG\n");
break;
default:
printf("Type is %d,check in mysql_com.h\n", field_ptr->type);
}
}
printf("\t Max width %ld \n", field_ptr->length);
if (field_ptr->flags & AUTO_INCREMENT_FLAG)
printf("\t Auto increments\n");
printf("\n");
}
}
int main()
{
int ret = 0;
int first_row = 1;
conn_ptr = mysql_init(NULL); //初始化
if (!conn_ptr)
{
printf("mysql_init failed!\n");
return -1;
} ret = mysql_options(conn_ptr, MYSQL_OPT_CONNECT_TIMEOUT, (const char *)&timeout); //设置超时选项
if (ret)
{
printf("Options Set ERRO!\n");
}
conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root", "这里写你数据库连接的密码", "testdb", 3306, NULL, 0); //连接MySQL testdb数据库,端口为3306
if (conn_ptr)
{
printf("Connection Succeed!\n"); ret = mysql_query(conn_ptr, "SELECT * FROM testTable"); //执行SQL语句
if (!ret)
{
res_ptr = mysql_use_result(conn_ptr);
if (res_ptr)
{
display_header();
printf("Retrieved %lu rows\n", (unsigned long)mysql_num_rows(res_ptr)); //在结果集合中返回行的数量
while ((sqlrow = mysql_fetch_row(res_ptr))) //返回store_result中得到的结构体,并从中检索单行
{
dispaly_row(conn_ptr);//打印表中的内容
}
} if (mysql_errno(conn_ptr))
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
return -2;
} mysql_free_result(res_ptr);
}
else
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
return -3;
} mysql_close(conn_ptr);
printf("Connection closed!\n");
}
else //错误处理
{
printf("Connection Failed!\n");
if (mysql_errno(conn_ptr))
{
printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
}
return -2;
} return 0;
}

  

7、Ubuntu下个人推荐使用Dbeaver来连接数据库,直接在商店中搜索Dbeaver下载即可。(DBeaver因为使用Java编写,所以在Windows和Mac上也有,是免费的数据库可视化软件中个人认为最好的)

注意默认的驱动仓库为maven主仓库,下载速度较慢,可以配置阿里云maven仓库(或者其他国内maven镜像都可以)来提高下载驱动的速度(记得移动到最顶上去)

Ubuntu下使用C语言连接Mysql 8.0客户端教程的更多相关文章

  1. Windows下用C语言连接Mysql注意问题

    原文:Windows下用C语言连接Mysql注意问题 环境是:在VS6.0 安装Mysql后,我们需要相应的头文件以及lib文件,所以安装过程必须是完整安装.否则不会生成include文件夹哦~ 具体 ...

  2. Linux centos 7/ubantu下: 用 C 语言连接 MySQL数据库

    前言:最近用IPC.socket做ATM.聊天项目,考虑到需要用到数据库,所以总结一下centos.ubantu环境下怎么用C语言操作数据库,例如常见的增删改查等! 一.Centos环境安装mysql ...

  3. Linux下C语言连接MySQL

    本文出自   http://blog.csdn.net/shuangde800 首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-cl ...

  4. c语言连接mysql数据库的实现方法

    C语言连接mysql数据库,需要相应的头文件和lib文件,如果你安装Mysql数据库,会在安装目录下找到这些库文件,如果没有安装,也可以在网上找到 我这里也有一份网上找到的:/201205/other ...

  5. R语言-连接MySQL数据库方法

    版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[+]   R语言连接数据库常用的方法有2种: 1.使用R数据库接口 连接MySQL,使用RMySQL包,使用前RMySQL包要先安 ...

  6. C语言连接mysql -insert-update

    C语言连接mysql数据库实现insert语句:数据库:test表:systeminfo CREATE TABLE `systeminfo` (  `id` int(11) NOT NULL AUTO ...

  7. Linux系统下 解决Qt5无法连接MySQL数据库的方法

    Linux平台下解决Qt5连接mysql数据库的问题:输入sudo apt-get install libqt5sql5-mysql解决,这种方法只能解决Qt是用sudo apt-get instal ...

  8. C语言连接MySql数据库

    C语言连接MySql数据库(CodeBlocks) 操作系统:Windows7(32位)编译软件:Code::Blocks 10.05数 据 库:mysql-5.1.62-win32 数据库内的数据: ...

  9. 在VS下用C语言连接SQLServer2008

    原文:在VS下用C语言连接SQLServer2008 step1:启动SQLSERVER服务 step2:打建立数据库test,在test库中建立test表(a varchar(200),b varc ...

随机推荐

  1. Struts2跟SpringMVC的区别

    1. 拦截机制不同 Struts2是类级别的拦截,每次请求就会创建一个Action,和Spring整合时Struts2的ActionBean注入作用域是原型模式prototype,然后通过setter ...

  2. 【论文考古】知识蒸馏 Distilling the Knowledge in a Neural Network

    论文内容 G. Hinton, O. Vinyals, and J. Dean, "Distilling the Knowledge in a Neural Network." 2 ...

  3. Java线程的实现/创建方式

    1.继承Thread类: Thread 类本质上是实现了 Runnable 接口的一个实例,代表一个线程的实例. 启动线程的唯一方法就是通过 Thread 类的 start()实例方法. start( ...

  4. WPF + Winform 解决管理员权限下无法拖放文件的问题

    wpf,winform混合解决管理员权限无法拖放文件的问题 学习自: https://zhuanlan.zhihu.com/p/343369663 https://zhuanlan.zhihu.com ...

  5. windows server 2016 2019修改远程端口操作

    一.修改3389远程端口 1,按"win+r"快捷键,在对话框中输入regedit 2, 找到路径 \HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro ...

  6. 攻防世界Web_ics_05

    题目: 题目描述:其他破坏者会利用工控云管理系统设备维护中心的后门入侵系统 题目场景:   1.进入云平台设备中心界面,查看以下源码发现?page= ,(点下云平台设备维护中心url里也能出?page ...

  7. Spring源码之BeanFactoryPostProcessor(后置处理器)

    Spring源码之BeanFactoryPostProcessor(后置处理器). 有点水平的Spring开发人员想必都知道BeanFactoryPostProcessor也就是常说的后置管理器,这是 ...

  8. Stroke

    // A simple blur shader, weighted on alphauniform sampler2D texture;void main(){    float radius = 0 ...

  9. [题解]第十一届北航程序设计竞赛预赛——D.最大公约数

    题目描述 给一个长度为n(1<=n<=100000)的正整数列,分成尽量多的非空段,使得每一段的最大公约数相等.一个数的最大公约数是它本身. 解题思路 要求每一段子列的gcd相等,不妨设为 ...

  10. Clickhouse 分布式表&本地表 &ClickHouse实现时序数据管理和挖掘

    一.CK 分布式表和本地表 (1)CK是一个纯列式存储的数据库,一个列就是硬盘上的一个或多个文件(多个分区有多个文件),关于列式存储这里就不展开了,总之列存对于分析来讲好处更大,因为每个列单独存储,所 ...