当前位置: 首页 > news >正文

mysql和c 连接数据库_c/c++连接mysql数据库

环境:win7 x64、vs2008、mysql

对于已经安装mysql的,查看mysql安装目录,如果安装目录下没有include和lib目录,

部分截图如下,从图左侧可看出,官网提供了c、c++、Python、J等语言的链接库,根据个人情况下载。

6c4144d4d99bf895fa135c5af6ccd9ee.png

下面开始配置vs2008,大致需要三步。

由于我们要使用Mysql的API,并且我们机子上肯定安装了Mysql数据库,所以我们要将工程的头文件路径指向Mysql安装目录的同文件mysql.h所在的位置,将连接库路径指向libmysql.lib所在的路径,

这两个文件一般在include、lib目录下。

新建一个项目,右键该项目,选择属性,弹出属性对话框。

第一:将x项目属性页的C/C++->常规->附加包含目录指向mysql.h所在的位置:C:\Program Files\MySQL\MySQL Server 5.1\include

bd6e3f71ce791a69ae6f8f15cef2ee51.png

第二:将项目属性页的链接器->常规->附加库目录指向libmysql.lib所在的路径:C:\Program Files\MySQL\MySQL Server 5.1\lib.

be0a76f27a252e7de097b338103ccebe.png

第三:将链接器->输入->附加依赖项中添加libmysql.lib。

5f72e628062088ac7fa4c1050afff6ae.png

通过上述配置后出现错误:

无法解析的外部符号 _mysql_close@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_free_result@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_num_fields@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_fetch_row@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_store_result@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_error@4,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_real_query@12,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_select_db@8,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_real_connect@32,该符号在函数 _main 中被引用

无法解析的外部符号 _mysql_init@4,该符号在

经过网友帮助,我将原来下载的64位mysql-connector卸载,又重新下了一个32位安装,结果错误消失,百思不得其解,可能是我的mysql数据库是32位的吧。

最后附上c++连接mysql的示例代码:

// test9.24.cpp : 定义控制台应用程序的入口点。

//

//#include

//#include

//#include //包含MySQL所需要的头文件

//#include //Socket,连接MySQL也需要用的

#include

#include "stdio.h"

#include "winsock.h"

#include "mysql.h"

MYSQL mysql, *sock; //声明MySQL的句柄

int main(void)

{

const char * host = "127.0.0.1"; //因为是作为本机测试,所以填写的是本地IP

const char * user = "root"; //这里改为你的用户名,即连接MySQL的用户名

const char * passwd = "123"; //这里改为你的用户密码

const char * db = "yiersan"; //这里改为你要连接的数据库的名字

unsigned int port = 3306; //这是MySQL的服务器的端口,如果你没有修改过的话就是3306。

const char * unix_socket = NULL; //unix_socket这是unix下的,我在Windows下,所以就把它设置为NULL

unsigned long client_flag = 0; //这个参数一般为0

int t;

const char * i_query = "select * from yes_msg"; //查询语句

MYSQL_RES * result; //保存结果集的 www.2cto.com

MYSQL_ROW row; //代表的是结果集中的一行

mysql_init(&mysql); //连接之前必须使用这个函数来初始化

if ( (sock = mysql_real_connect(&mysql, host, user, passwd, db, port, unix_socket, client_flag) ) == NULL ) //连接MySQL

{

printf("连接失败,原因是: \n");

fprintf(stderr, " %s\n", mysql_error(&mysql));

exit(1);

}

else

{

fprintf(stderr, "连接MySQL成功!!\n");

}

if ( mysql_query(&mysql, i_query) != 0 ) //如果连接成功,则开始查询

{

fprintf(stderr, "查询失败!\n");

exit(1);

}

else

{

if ( (result = mysql_store_result(&mysql)) == NULL ) //保存查询的结果

{

fprintf(stderr, "保存结果集失败!\n");

exit(1);

}

else

{

while ( (row = mysql_fetch_row(result)) != NULL ) //读取结果集中的数据,返回的是下一行。因为保存结果集时,当前的游标在第一行【之前】

{

printf("name is %s\t", row[0]); //打印当前行的第一列的数据

printf("age is %s\t\n", row[1]); //打印当前行的第二列的数据

}

}

}

mysql_free_result(result); //释放结果集

mysql_close(sock);

scanf("%d",&t);//关闭连接

system("pause");

exit(EXIT_SUCCESS);

}

http://www.xdnf.cn/news/818173.html

相关文章:

  • 单片机课设 - 电子时钟 (仿真,仿真代码,实验板代码)
  • pip 通过 requirements 文件,批量下载python包,批量离线安装python包
  • N点虚拟主机提权 - cracer_CSDN
  • telegram怎么改密码?
  • CreateFileMapping来进行进程间的通信和使用信号量来进行同步操作——进程间实现图片传输
  • 入门编程的方法和步骤
  • 初步认识filter
  • DELPHI XE5安装
  • 购物兔最新版本3.2.26.100,上小众推荐和搜狐新闻啦~
  • 腾讯对外发布微博开放平台 API
  • Pulp Fiction (低俗小说)
  • 全面解析找不到msvcp71.dll无法继续执行的原因及修复方法
  • 内网即时通讯软件有哪些?局域网聊天工具
  • 云主机性价比分析
  • tpx色卡电子版_潘通色卡电子版Pantone TPX(三)
  • RAC RMAN 通道配置 RMAN-12001 RMAN-12001 RMAN-10008 RMAN-10003 ORA-01017 错误
  • 中国最火最流行的40个博客网站
  • 浅谈芯片解密的五大方法
  • 最优化之最速下降法
  • java实现大文件传输
  •  Windows socket之IO完成端口(IOCP)模型开发
  • Microsoft Visual Studio 2008 SP1 简体中文版 安装图集
  • 怎样取消shutdown关机命令?-shutdown命令的使用解析
  • Windbg调试命令详解
  • SQL COUNT() 函数
  • html的表单标签(上):form标签和input标签
  • 图像分割—基于阈值处理的基本方法
  • Ubuntu 16.04 一系列软件安装命令,包括QQ、搜狗、Chrome、vlc、网易云音乐安装方法
  • Android SDK代理服务器解决国内不能更新下载问题
  • 分享一些嵌入式开发常用终端工具