Ubuntu下使用C语言连接Mysql 8.0客户端教程

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镜像都可以)来提高下载驱动的速度(记得移动到最顶上去)

 

posted @ 2021-10-08 22:17  JessieLin  阅读(347)  评论(0编辑  收藏  举报