热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

VS用c语言连接mysql,c语言连接mysql完整演示

#include#includeintmain(){MYSQL*conn;创建一个指向mysql数据类型的指针connmysql_init(NULL);mysql的初始化if(!c

#include

#include

int main() {

MYSQL *conn; //创建一个指向mysql数据类型的指针

conn=mysql_init(NULL); //mysql的初始化

if (!conn) //判断是否初始化成功

{

printf("mysql初始化失败!\n");

return EXIT_FAILURE;

}

conn=mysql_real_connect(conn,"localhost","lewis","123","test",0,NULL,0);

//用户名为lewis,密码为123,连接的数据库为test

if (conn)

{

printf("数据库连接成功!\n");

}

else

printf("数据库连接失败!\n");

mysql_close(conn); //关闭mysql连接

return 0;

}

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

2.若不存在,请看下一级目录/usr/include/mysql/,若存在mysql.h,c语言中请使用

#include

很好测试,直接去目录里面找,或者在Clion中看是否有代码提示

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

d80a2faaea766fd6923f16271a1f3f9a.png

标签:gcc,演示,target,job,mysql,CMakeFiles,include,连接

来源: https://www.cnblogs.com/nanfengnan/p/14725292.html



推荐阅读
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 在Kubernetes上部署JupyterHub的步骤和实验依赖
    本文介绍了在Kubernetes上部署JupyterHub的步骤和实验所需的依赖,包括安装Docker和K8s,使用kubeadm进行安装,以及更新下载的镜像等。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何在php文件中添加图片?
    本文详细解答了如何在php文件中添加图片的问题,包括插入图片的代码、使用PHPword在载入模板中插入图片的方法,以及使用gd库生成不同类型的图像文件的示例。同时还介绍了如何生成一个正方形文件的步骤。希望对大家有所帮助。 ... [详细]
  • 本文介绍了在Ubuntu下制作deb安装包及离线安装包的方法,通过备份/var/cache/apt/archives文件夹中的安装包,并建立包列表及依赖信息文件,添加本地源,更新源列表,可以在没有网络的情况下更新系统。同时提供了命令示例和资源下载链接。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • Ubuntu安装常用软件详细步骤
    目录1.GoogleChrome浏览器2.搜狗拼音输入法3.Pycharm4.Clion5.其他软件1.GoogleChrome浏览器通过直接下载安装GoogleChro ... [详细]
  • phpcomposer 那个中文镜像是不是凉了 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
author-avatar
Adrian
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有