c/C++对mysql数据库进行操作笔记


对mysql数据库的操作一般分一下几步:

第一:包含mysql头文件及定义变量

#include <mysql.h>
MYSQL *mysql_conn;

MYSQL_RES *res;

MYSQL_ROW row;
定义一个MYSQL结构体指针存放mysql操作的句柄

定义个MYSQL_RES 结构体指针存放使用语句操作数据库返回结果

定义一个MYSQL_ROW结构体


第二:初始化mysql

mysql_init(mysql_conn)

或者

mysql_conn=mysql_init(NULL)

第三:连接到mysql库

mysql_real_connect(mysql_conn,IP_address,username,password,database,port,NULL,0)
用username 密码password 连接到IP_address:port 的databse库

连接失败返回NULL


第四:执行数据库语句

mysql_query(mysql_conn,"语句")
执行成功返回0


第五:保存执行语句返回结果

res=mysql_store_result(mysql_conn);

第六:使用循环查询结果

while(row=mysql_fetch_row(res))
{
        处理结果;
}


举例:

  1 #include <iostream>
  2 #include <mysql/mysql.h>
  3 
  4 using namespace std;
  5 
  6 int main()
  7 {
  8         MYSQL mysql_conn;
  9         MYSQL_RES *res;
 10         MYSQL_ROW row;
 11 
 12         char *ipaddr="localhost";
 13         char *username="root";
 14         char *password="123456";
 15         char *database_name="database";
 16 
 17         if(mysql_init(&mysql_conn)==NULL)
 18         {
 19                 cout<<"初始化失败"<<endl;
 20                 return 0;
 21         }
 22         if(mysql_real_connect(&mysql_conn,ipaddr,username,password,database_name,3306,NULL,0)==NULL)
 23         {
 24                 cout<<"连接失败"<<endl;
 25                 return 0;
 26         }
 27         cout<<"连接成功"<<endl;
 28         if(mysql_query(&mysql_conn,"show tables"))
 29         {
 30                 cout<<"query error!"<<endl;
 31                 return 0;
 32         }
 33         res=mysql_store_result(&mysql_conn);
 34         cout<<"Tables in "<<database_name<<":"<<endl;
 35         while((row=mysql_fetch_row(res))!=NULL)
 36                 cout<<row[0]<<endl;
 37         mysql_free_result(res);
 38         mysql_close(&mysql_conn);
 39         return 0;
 40 }










  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值