Linux下C++连MySQL数据库

  1.查看本地有没有安装mysql,命令就是mysql,如果有这个命令就表示安装了mysql数据库软件。如果没有就自行安装。
  MySQL-server-4.0.16-0.i386.rpm   
  MySQL-client-4.0.16-0.i386.rpm


  2.查看本地有没有安装mysql的开发包。命令是 `mysql_config --cflags --libs` 如果有安装就会有一串编译选项和连接库。如果没有就自行安装 mysql-devel-*****的rpm包 后面是版本号。mysql开发包提供了基本操作接口。安装后头文件在/usr/include/mysql 而动态库在 /usr/lib/mysql 上。

 

  3.创建一个用于练习的数据库test.进入mysql> 然后依次输入:

    mysql>create database test; 

    mysql>use test;    //切换到test数据库中

    mysql> create table test(name varchar(255),num int(10) ); //创建一个叫test的表

    mysql>show create table test;  //显示刚才创建的表信息

    mysql> select * from test;   //查询test表中数据

    mysql>quit

 

  4.编写一个c++程序,代码如下:

 1 #include <stdio.h>
 2 #include <mysql.h>
 3 
 4 int main(int argc,char *argv[])
 5 {
 6     MYSQL conn;
 7     int res;
 8     mysql_init(&conn);
 9     if(mysql_real_connect(&conn,"localhost","root","","test",0,NULL,CLIENT_FOUND_ROWS)) //"root":数据库管理员 "":root密码 "test":数据库的名字
10     {
11       printf("connect success!\n");
12       res=mysql_query(&conn,"insert into test values(‘user‘,‘123456‘)");
13       if(res)
14       {
15           printf("error\n");
16       }
17       else
18       {
19           printf("OK\n");
20       }
21       mysql_close(&conn);
22     }
23     return 0;
24 }

  代码不是很难理解,就不解释了。

 

  5.编译程序

  使用的编译代码(注意哪两个不是单引号而是反单引号)

g++ test.cpp `mysql_config --cflags --libs` -o test

  

  6.运行代码

    ./test

 

  7.再次查看数据库

    mysql>use test;

    mysql>select * from test;

    这样就可以查看到插入的信息了。

 

 ================我是分割线============================

  1 #include <stdio.h>
  2 #include <mysql.h>
  3 #define HOST "localhost"
  4 #define USERNAME "root"
  5 #define PASSWORD ""
  6 #define DATABASE "test"
  7 
  8 void insert_sql(char * sql);
  9 void query_sql(char* sql);
 10 int main(int argc,char *argv[])
 11 {
 12     //insert_sql("insert into test values(‘user‘,‘123456‘)");
 13     query_sql("select * from test");
 14     return 0;
 15 }
 16 
 17 void insert_sql(char * sql)
 18 {
 19     MYSQL conn;
 20     int res;
 21     mysql_init(&conn);
 22     if(mysql_real_connect(&conn,"localhost","root","","test",0,NULL,CLIENT_FOUND_ROWS))
 23     {
 24     printf("connect success!\n");
 25     res=mysql_query(&conn,sql);
 26     if(res)
 27     {
 28         printf("error\n");
 29     }
 30     else
 31     {
 32         printf("OK\n");
 33     }
 34     mysql_close(&conn);
 35     }
 36 
 37 }
 38 
 39 void query_sql(char* sql) 
 40 {
 41     MYSQL my_connection; /*这是一个数据库连接*/
 42     int res; /*执行sql語句后的返回标志*/
 43     MYSQL_RES *res_ptr; /*指向查询结果的指针*/
 44     MYSQL_FIELD *field; /*字段结构指针*/
 45     MYSQL_ROW result_row; /*按行返回的查询信息*/
 46 
 47     int row, column; /*查询返回的行数和列数*/
 48     int i, j; /*只是控制循环的两个变量*/
 49 
 50     /*初始化mysql连接my_connection*/
 51     mysql_init(&my_connection);
 52 
 53     /*这里就是用了mysql.h里的一个函数,用我们之前定义的那些宏建立mysql连接,并
 54      *     返回一个值,返回不为空证明连接是成功的*/
 55     if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD, DATABASE, 0, NULL, CLIENT_FOUND_ROWS)) 
 56     {
 57     /*连接成功*/
 58     printf("数据库查询query_sql连接成功!\n");
 59     /*这句话是设置查询编码为utf8,这样支持中文*/
 60     mysql_query(&my_connection, "set names utf8");
 61 
 62     /*下面这句话就是用mysql_query函数来执行我们刚刚传入的sql語句,
 63      *         这会返回一个int值,如果为0,证明語句执行成功*/
 64     res = mysql_query(&my_connection, sql);
 65 
 66     if (res) 
 67     { /*现在就代表执行失败了*/
 68         printf("Error: mysql_query !\n");
 69         /*不要忘了关闭连接*/
 70         mysql_close(&my_connection);
 71     }
 72     else 
 73     { 
 74         /*现在就代表执行成功了*/
 75         /*将查询的結果给res_ptr*/
 76         res_ptr = mysql_store_result(&my_connection);
 77 
 78         /*如果结果不为空,就把结果print*/
 79         if (res_ptr) 
 80         {
 81         /*取得結果的行数和*/
 82         column = mysql_num_fields(res_ptr);
 83         row = mysql_num_rows(res_ptr) + 1;
 84         printf("查询到 %lu 行 \n", row);
 85 
 86         /*输出結果的字段名*/
 87         for (i = 0; field = mysql_fetch_field(res_ptr); i++)
 88             printf("%s\t", field->name);
 89         printf("\n");
 90 
 91         /*按行输出結果*/
 92         for (i = 1; i < row; i++)
 93         {
 94             result_row = mysql_fetch_row(res_ptr);
 95             for (j = 0; j < column; j++)
 96             printf("%s\t", result_row[j]);
 97             printf("\n");  
 98         }  
 99 
100         }  
101 
102         /*不要忘了关闭连接*/  
103         mysql_close(&my_connection);  
104     }  
105     }  
106 } 
完整代码

  其实数据库的增加,删除,更新等操作比较简单,都是返回一个值表示成功与否。而查询比较麻烦。返回一个结果集,所以操作起来比较麻烦! 

 

参考资料:

http://blog.csdn.net/fykhlp/article/details/5950485#

Linux下C++连MySQL数据库,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。