• c语言连接mysql完整演示


     1.连接数据库代码

    #include <stdio.h>
    #include <mysql/mysql.h>
    
    int main() {
        MYSQL *conn;     //创建一个指向mysql数据类型的指针
        conn=mysql_init(NULL);   //mysql的初始化
        if (!conn)         //判断是否初始化成功
        {
            printf("mysql初始化失败!
    ");
            return EXIT_FAILURE;
        }
        conn=mysql_real_connect(conn,"localhost","lewis","123","test",0,NULL,0);
        //用户名为lewis,密码为123,连接的数据库为test
        if (conn)
        {
            printf("数据库连接成功!
    ");
        }
        else
            printf("数据库连接失败!
    ");
        mysql_close(conn);  //关闭mysql连接
        return 0;
    }

    2.创建数据库 语句

    CREATE DATABASE test(
    name varchar(20),
    num int(4),
    sex char(4)
    );

    C语言连接mysql时,注意事项:

    1.首先明确,我的系统是ubuntu,我的mysql是5.7*版本
    2.使用c语言管理mysql数据库,
    首先,我们需要安装在linux下操作mysql的多依赖库,命令如下:
    //如果你有clion集成开发环境,那么一般这个都是有的,但以防万一,你还是下载试一下.

    sudo apt-get install libmysqlclient-dev sudo apt-get install libmysqld-dev

     3.开发环境,如果你是没有环境,直接用gcc那么,执行下面命令

    gcc -g -o demo -I /usr/include/mysql/ demo.c -L /usr/lib64/mysql/ -lmysqlclient -lz
    //意思是:将demo.c文件编译为可执行文件demo,同时使用/user/include/mysql目录作为优先头文件
    演示和分析见:https://www.cnblogs.com/nanfengnan/p/14725278.html
    //main.c 是你所要编译的源文件
    //mysql  -o 后的mysql 是自定义生成的文件名
    
    //补充一点gcc知识,其实你也可以去linux里面,输入man gcc自己去看命令
    1.gcc -o 文件名  //指定输出的文件名,默认文件名为:文件名.out
    2.gcc -c 文件名 //编译或者汇编源文件,但不链接
    3.gcc -g  头文件目录    //可执行程序包含调试信息,加g选项是为了,生成调试信息供gdb调试,不加g无法用gdb调试
    4.gcc -I //指定使用的目录作为第一个寻找使用的头文件目录
    reference:https://www.cnblogs.com/alan666/p/8311984.html

     4.使用Clion开发环境问题

    前面步骤都一样,操作步骤:1->2->4

    使用clion和gcc最大的差别就是:clion得修改一下CMakeLists.txt文件

    cmake_minimum_required(VERSION 3.17)
    project(job C)
    
    set(CMAKE_C_STANDARD 99)
    
    //上边是CMakeLists.txt原本的内容,不要修改
    //下边是要添加和修改的内容 add_executable(job main.c) target_link_libraries(CProjectName mysqlclient

    //重要注释:必须看啊
    1.target_link_libraries中的CProjectName替换成实际你的C语言项目名称)
    2.target_link_libraries中引入的链接库为mysqlclient,而不是libmysqlclient,使用libmysqlclient会报错 划重点

    报错如下:所以一定要注意这里

    ====================[ Build | job | Debug ]=====================================
    /opt/clion/clion-2020.3.2/bin/cmake/linux/bin/cmake --build /home/lewis/program/c/job/cmake-build-debug --target job -- -j 6
    Scanning dependencies of target job
    [ 50%] Building C object CMakeFiles/job.dir/main.c.o
    [100%] Linking C executable job
    /usr/bin/ld: 找不到 -llibmysqlclient
    collect2: error: ld returned 1 exit status
    CMakeFiles/job.dir/build.make:103: recipe for target 'job' failed
    make[3]: *** [job] Error 1
    CMakeFiles/Makefile2:95: recipe for target 'CMakeFiles/job.dir/all' failed
    make[2]: *** [CMakeFiles/job.dir/all] Error 2
    CMakeFiles/Makefile2:102: recipe for target 'CMakeFiles/job.dir/rule' failed
    make[1]: *** [CMakeFiles/job.dir/rule] Error 2
    Makefile:138: recipe for target 'job' failed
    make: *** [job] Error 2

    3.查看mysql.h文件目录

    查看mysql文件,
    1./usr/include/是否存在mysql.h ,若存在,在c语言中使用时用 #include<mysql.h> 2.若不存在,请看下一级目录/usr/include/mysql/,若存在mysql.h,c语言中请使用 #include<mysql/mysql.h>
    很好测试,直接去目录里面找,或者在Clion中看是否有代码提示

     CLion下连接数据库结果如下:

  • 相关阅读:
    Linux下使用select延时
    update不能直接使用select的返回结果
    C++类模板声明与定义为何不能分开
    MySQL开启日志记录执行过的SQL语句
    如何使用FastCGI处理自定义HTTP头
    MongoDB添加认证
    Ubuntu16.04安装MongoDB
    nginx: [emerg] getpwnam(“www”) failed
    C++ 智能指针(一)
    协同过滤
  • 原文地址:https://www.cnblogs.com/nanfengnan/p/14725292.html
Copyright © 2020-2023  润新知