欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

mysql的安装、C++访问mysql数据库、编码设置问题_MySQL

程序员文章站 2022-04-22 10:24:21
...
一.mysql的安装,这个相对简单,直接去官网下载mysql安装程序,就可以完成安装过程,网上有很多安装教程,这个没什么注意事项。

二、C++访问mysql,主要是用到mysql定义的头文件,内部定义了各种数据结构和函数,比如MYSQL,MYSQL_RES,MYSQL_ROW,mysql_real_connect等等一系列的结构和函数。这里要注意的就是将头文件及lib文件以及dll文件配置到当前开发环境来进行访问mysql数据库。

以最新的vs2013作为示例说一下配置过程。为了写的清晰点,在网上找了几张图来说明。

1.要指定mysql所用到的头文件,可以直接将mysql安装目录下的include文件下的头文件拷贝到vs安装目录的include目录下,但是一般我们都是为编译器指定一个额外的头文件目录即可。右键工程-> properties然后如下图,在这个附加包含目录(Additional Include Directory)添加上mysql的include文件,此文件在mysql安装目录下,例如本人的安装目录

C:\Program Files\MySQL\MySQL Server 5.1\include

mysql的安装、C++访问mysql数据库、编码设置问题_MySQL


2.指定mysql的库文件

在连接器的常规下面,附加库目录(Additional Liberay Directory)添加上mysql安装目录下的lib文件夹的路径,本人的安装目录:

C:\Program Files\MySQL\MySQL Server 5.5\lib

本文作者:csdn iaccepted 凌风

mysql的安装、C++访问mysql数据库、编码设置问题_MySQL


3.添加额外依赖(AdditionalDependencies),如下图,指定libmysql.lib,其实就是在上面设置的库文件中指定用哪个lib文件而已。

mysql的安装、C++访问mysql数据库、编码设置问题_MySQL


ok,到这里环境就配置完成,接下来就可以进行连接mysql并进行数据库操作。

本文作者:csdn iaccepted 凌风


在vs2013中新建一个工程,然后根据mysql的官方API就可以完成数据库操作。

如下:

[cpp] view plaincopyprint?mysql的安装、C++访问mysql数据库、编码设置问题_MySQLmysql的安装、C++访问mysql数据库、编码设置问题_MySQL

  1. #include "person.h"
  2. #include
  3. #include
  4. #include
  5. #include
  6. #include
  7. using namespace std;
  8. int main(){
  9. MYSQL *con;
  10. MYSQL_RES *results;
  11. MYSQL_ROW record;
  12. char dbuser[30] = "root";
  13. char dbpasswd[30] = "123456";
  14. char dbhost[30] = "localhost";
  15. char dbname[30] = "person";
  16. char tname[30] = "person";
  17. char *query = nullptr;
  18. con = mysql_init(nullptr);
  19. if (!mysql_real_connect(con, dbhost, dbuser, dbpasswd, dbname, 3306, NULL, 0)){
  20. cerr "Failed to connect database"
  21. exit(2);
  22. }
  23. mysql_set_character_set(con, "gbk");
  24. mysql_query(con, "insert into person(id, name) values('370983198811256977', '个')");
  25. mysql_query(con, "select name,id from person where id = '370983198811256977'");
  26. results = mysql_store_result(con);
  27. cout
  28. while ((record = mysql_fetch_row(results))){
  29. cout
  30. }
  31. mysql_close(con);
  32. return 0;
  33. }