热门标签 | 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



推荐阅读
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ... [详细]
  • 搭建Jenkins、Ant与TestNG集成环境
    本文详细介绍了如何在Ubuntu 16.04系统上配置Jenkins、Ant和TestNG的集成开发环境,涵盖从安装到配置的具体步骤,并提供了创建Windows Slave节点及项目构建的指南。 ... [详细]
  • 编程挑战:2019 Nitacm 校赛 D 题 - 雷顿女士与分队(高级版)
    本文深入解析了2019年Nitacm校赛D题——雷顿女士与分队(高级版),详细介绍了问题背景、解题思路及优化方案。 ... [详细]
  • 哈密顿回路问题旨在寻找一个简单回路,该回路包含图中的每个顶点。本文将介绍如何判断给定的路径是否构成哈密顿回路。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 解决Anaconda安装TensorFlow时遇到的TensorBoard版本问题
    本文介绍了在使用Anaconda安装TensorFlow时遇到的“Could not find a version that satisfies the requirement tensorboard”错误,并提供详细的解决方案,包括创建虚拟环境和配置PyCharm项目。 ... [详细]
  • 本文介绍如何利用栈数据结构在C++中判断字符串中的括号是否匹配。通过顺序栈和链栈两种方式实现,并详细解释了算法的核心思想和具体实现步骤。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
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社区 版权所有