linux c mysql 开发

二、安装mysql开发包

sudo apt-get install libmysqlclient-dev

Ubuntu Package查询地址(输入关键词查询到最新的package名字,比如libmysqlclient,然后装最新的版本):

http://packages.ubuntu.com/

三、如何调用MYSQL库文件

加入头文件: #include <mysql/mysql.h>

#include <mysql/mysql.h>
#include "stdio.h"
int main()
{
printf("i love c\n");
return 0;
}  

保存为test.c

四、编译方法

gcc -o test test.c -lmysqlclient

或(c++程序)

g++ -o test test.cpp -lmysqlclient

还是找不到mysql.h?添加参数-I/usr/include/mysql/看看(示例如下),假设mysql.h在该目录下。

gcc -o test test.c -lmysqlclient -I/usr/include/mysql/

执行:

./test

例子






MYSQL DbObj;  //handle
MYSQL_RES *pRes; //result
MYSQL_ROW  sqlrow; //row


int main()
{
char strsql[200];
char username[20];
char password[20];

sprintf(username,"root");
sprintf(password,"123456");

mysql_init(&DbObj);
if(!mysql_real_connect(&DbObj,"192.168.75.131",username,password,"test",0,NULL,0) )
{
return 0;
}
sprintf(strsql,"select * from person");
int res=mysql_query(&DbObj,strsql);
pRes=mysql_use_result(&DbObj);
if( (sqlrow=mysql_fetch_row(pRes))!=NULL )
{
mysql_free_result(pRes);//释放记录集
printf("Ok.\n");
  }
mysql_close(&DbObj);






再次改进,读字段名和记录

#include <mysql/mysql.h>
#include "stdio.h"
#include <string.h>




MYSQL DbObj;  //handle
MYSQL_RES *pRes; //result
MYSQL_ROW  sqlrow; //row


void display_row();
void display_head();


int main()
{
char strsql[200];
char username[20];
char password[20];

int first_row=1;
sprintf(username,"root");
sprintf(password,"123456");

mysql_init(&DbObj);
if(!mysql_real_connect(&DbObj,"192.168.75.131",username,password,"test",0,NULL,0) )
{
return 0;
}
sprintf(strsql,"select * from person");
int res=mysql_query(&DbObj,strsql);
if(res)
{
fprintf(stderr,"select error: %s\n",mysql_error(&DbObj) );
}
else
{
pRes=mysql_use_result(&DbObj);
if(pRes)
{
while( (sqlrow=mysql_fetch_row(pRes))!=NULL )
{
if(first_row)
{
display_head();
first_row=0;
}

display_row();

}
}

}
mysql_close(&DbObj);



/*
  读字段名
*/
void display_head()
{
MYSQL_FIELD *field_ptr;
printf("column  details:\n");
while( (field_ptr=mysql_fetch_field(pRes))!=NULL )
{
printf("Name:%s\t\n",field_ptr->name);
printf("Type:\t" );
if(IS_NUM(field_ptr->type))
    {
        printf("Numeric filed\n");
    }
    else
    {
    switch(field_ptr->type)
    {
    case FIELD_TYPE_VAR_STRING:
    printf("varchar \n");
    break;
    case FIELD_TYPE_LONG:
    printf("Long \n");
    break;
    default:
    printf("Type is %d,check in mysql_com.h\n",field_ptr->type);
    }
    }
    
}
}
/*
 读行记录
*/
void display_row()
{
    unsigned int field_count;


    field_count = 0;
    while(field_count<mysql_field_count(&DbObj))
    {
        if(sqlrow[field_count]) printf("%s ",sqlrow[field_count]);
        else printf("NULL");
        field_count++;
    }
    printf("\n");
}




继续改进,加上事务,加上执行insert ,update


#include <mysql/mysql.h>
#include "stdio.h"
#include <string.h>




MYSQL DbObj;  //handle
MYSQL_RES *pRes; //result
MYSQL_ROW  sqlrow; //row


void display_row();
void display_head();


int main()
{
char strsql[200];
char insrtsql[200];
char username[20];
char password[20];

int first_row=1;
int t=-1;
sprintf(username,"root");
sprintf(password,"lovepxm");

mysql_init(&DbObj);
if(!mysql_real_connect(&DbObj,"192.168.75.131",username,password,"test",0,NULL,0) )
{
fprintf(stderr,"无法连接到数据库,错误原因是:%s/n",mysql_error(&DbObj));
return 0;
}
sprintf(insrtsql,"%s","insert into person (person_name) Values ('xx')");
  mysql_query(&DbObj,insrtsql);
 
  t=mysql_real_query(&DbObj,"SET AUTOCOMMIT =0",(unsigned int)strlen("SET AUTOCOMMIT =0"));
  if(t){
     printf("启用手工事务失败\n");
  }else{
     printf("启用手工事务成功\n");
  }
  t=mysql_real_query(&DbObj,"Begin ;",(unsigned int)strlen("Begin ;")); //开启事务
  
  sprintf(insrtsql,"%s","insert into person (person_name) Values ('yyyy')");
  int inset_1=mysql_query(&DbObj,insrtsql);
  
  sprintf(insrtsql,"%s","insert into person (person_name) Values ('ok')");
  int inset_2=mysql_query(&DbObj,insrtsql);      
  
  if(inset_1==0 && inset_2==0 ){    //结束事务
      printf("事务提交\n");
      t=mysql_real_query(&DbObj,"COMMIT;",(unsigned int)strlen("COMMIT;"));
  }else{
      printf("事务回滚\n");
      t=mysql_real_query(&DbObj,"ROLLBACK;",(unsigned int)strlen("ROLLBACK;"));
  }
  
sprintf(strsql,"select * from person");
int res=mysql_query(&DbObj,strsql);
if(res)
{
fprintf(stderr,"select error: %s\n",mysql_error(&DbObj) );
}
else
{
pRes=mysql_use_result(&DbObj);
if(pRes)
{
while( (sqlrow=mysql_fetch_row(pRes))!=NULL )
{
if(first_row)
{
display_head();
first_row=0;
}

display_row();

}
}

}
mysql_close(&DbObj);



/*
  读字段名
*/
void display_head()
{
MYSQL_FIELD *field_ptr;
printf("column  details:\n");
while( (field_ptr=mysql_fetch_field(pRes))!=NULL )
{
printf("Name:%s\t\n",field_ptr->name);
printf("Type:\t" );
if(IS_NUM(field_ptr->type))
    {
        printf("Numeric filed\n");
    }
    else
    {
    switch(field_ptr->type)
    {
    case FIELD_TYPE_VAR_STRING:
    printf("varchar \n");
    break;
    case FIELD_TYPE_LONG:
    printf("Long \n");
    break;
    default:
    printf("Type is %d,check in mysql_com.h\n",field_ptr->type);
    }
    }
    
}
}
/*
 读行记录
*/
void display_row()
{
    unsigned int field_count;


    field_count = 0;
    while(field_count<mysql_field_count(&DbObj))
    {
        if(sqlrow[field_count]) printf("%s ",sqlrow[field_count]);
        else printf("NULL");
        field_count++;
    }
    printf("\n");
}


http://www.metsky.com/archives/554.html

http://www.cnblogs.com/co1d7urt/archive/2012/10/23/2735320.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值