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博客),经过测试可以正常打印数据库的内容

  1. #include <mysql/mysql.h>
  2. //注意:apt install libmysqlclient-dev即可
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5.  
  6. MYSQL *conn_ptr;
  7. MYSQL_RES *res_ptr;
  8. MYSQL_ROW sqlrow;
  9. unsigned int timeout = 7; //超时时间7秒
  10.  
  11. void dispaly_row(MYSQL *ptr)
  12. {
  13. unsigned int field_count = 0;
  14. while (field_count < mysql_field_count(ptr)) //返回在结果结合中字段的数目
  15. {
  16. printf("%s", sqlrow[field_count]);
  17. field_count++;
  18. }
  19. printf("\n");
  20. }
  21.  
  22. void display_header()
  23. {
  24. MYSQL_FIELD *field_ptr;
  25. printf("Column details:\n");
  26. while ((field_ptr = mysql_fetch_field(res_ptr)) != NULL) //返回列的定义字段信息
  27. {
  28. printf("\t Name:%s\n", field_ptr->name);
  29. printf("\t Type:");
  30. if (IS_NUM(field_ptr->type)) //若字段类型为数字
  31. {
  32. printf("Numeric field\n");
  33. }
  34. else
  35. {
  36. switch (field_ptr->type)
  37. {
  38. case FIELD_TYPE_VAR_STRING:
  39. printf("VACHAR\n");
  40. break;
  41. case FIELD_TYPE_LONG:
  42. printf("LONG\n");
  43. break;
  44. default:
  45. printf("Type is %d,check in mysql_com.h\n", field_ptr->type);
  46. }
  47. }
  48. printf("\t Max width %ld \n", field_ptr->length);
  49. if (field_ptr->flags & AUTO_INCREMENT_FLAG)
  50. printf("\t Auto increments\n");
  51. printf("\n");
  52. }
  53. }
  54. int main()
  55. {
  56. int ret = 0;
  57. int first_row = 1;
  58. conn_ptr = mysql_init(NULL); //初始化
  59. if (!conn_ptr)
  60. {
  61. printf("mysql_init failed!\n");
  62. return -1;
  63. }
  64.  
  65. ret = mysql_options(conn_ptr, MYSQL_OPT_CONNECT_TIMEOUT, (const char *)&timeout); //设置超时选项
  66. if (ret)
  67. {
  68. printf("Options Set ERRO!\n");
  69. }
  70. conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root", "这里写你数据库连接的密码", "testdb", 3306, NULL, 0); //连接MySQL testdb数据库,端口为3306
  71. if (conn_ptr)
  72. {
  73. printf("Connection Succeed!\n");
  74.  
  75. ret = mysql_query(conn_ptr, "SELECT * FROM testTable"); //执行SQL语句
  76. if (!ret)
  77. {
  78. res_ptr = mysql_use_result(conn_ptr);
  79. if (res_ptr)
  80. {
  81. display_header();
  82. printf("Retrieved %lu rows\n", (unsigned long)mysql_num_rows(res_ptr)); //在结果集合中返回行的数量
  83. while ((sqlrow = mysql_fetch_row(res_ptr))) //返回store_result中得到的结构体,并从中检索单行
  84. {
  85. dispaly_row(conn_ptr);//打印表中的内容
  86. }
  87. }
  88.  
  89. if (mysql_errno(conn_ptr))
  90. {
  91. printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
  92. return -2;
  93. }
  94.  
  95. mysql_free_result(res_ptr);
  96. }
  97. else
  98. {
  99. printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
  100. return -3;
  101. }
  102.  
  103. mysql_close(conn_ptr);
  104. printf("Connection closed!\n");
  105. }
  106. else //错误处理
  107. {
  108. printf("Connection Failed!\n");
  109. if (mysql_errno(conn_ptr))
  110. {
  111. printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息
  112. }
  113. return -2;
  114. }
  115.  
  116. return 0;
  117. }

  

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. Involuting Bunny! (2021.8)

      CF1555F & Submission.   Tags:「A.生成树」「B.Tricks」   分类处理询问的 trick:连接两个连通块的边显然合法,先用这些边构建生成森林.发现每条边 ...

  2. Solution -「LOCAL」Drainage System

    \(\mathcal{Description}\)   合并果子,初始果子的权值在 \(1\sim n\) 之间,权值为 \(i\) 的有 \(a_i\) 个.每次可以挑 \(x\in[L,R]\) ...

  3. Redis 源码简洁剖析 13 - RDB 文件

    RDB 是什么 RDB 文件格式 Header Body DB Selector AUX Fields Key-Value Footer 编码算法说明 Length 编码 String 编码 Scor ...

  4. ASP.NET Core 6框架揭秘实例演示[07]:文件系统

    ASP.NET Core应用具有很多读取文件的场景,如读取配置文件.静态Web资源文件(如CSS.JavaScript和图片文件等).MVC应用的视图文件,以及直接编译到程序集中的内嵌资源文件.这些文 ...

  5. [旧][Android] LayoutInflater 工作流程

    备注 原发表于2016.06.20,资料已过时,仅作备份,谨慎参考 前言 感觉很长时间没写文章了,这个星期因为回家和处理项目问题,还是花了很多时间的.虽然知道很多东西如果只是看一下用一次,很快就会遗忘 ...

  6. NFA转化为DFA

    NFA(不确定的有穷自动机)转化为DFA(确定的有穷自动机) NFA转换DFA,通常是将带空串的NFA(即:ε-NFA)先转化为不带空串的NFA(即:NFA),然后再转化为DFA. 提示:ε是空串的意 ...

  7. Qt:QFile、QIODevice

    QFile 0.说明 QFile是读写文件的类,这里的文件包括文本文件.二进制文件.资源文件. 通常情况下,文件读写使用QFile.QTextStream.QDataStream就够了. file n ...

  8. Leaflet:控件Control相关

    Leaflet官方文档中只给出了4种控件:Zoom.Attribution.Layers.Scale:它们都是继承自Control类,具体可以参考Control. Control Zoom.Scale ...

  9. JZ-057-二叉树的下一个结点

    二叉树的下一个结点 题目描述 给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 题目链接: 二叉树的下一个结点 代 ...

  10. pthon语法

    1.条件语句 #找到a.b.c中最大的数,其中and是逻辑运算符"且"的意思 if a>b and a>c: print(a) elif b>a and b> ...