linux c mysql
来源:互联网 发布:mac的excel数据有效性 编辑:程序博客网 时间:2024/04/29 02:06
转载自:http://blog.csdn.net/pdw2009/article/details/22224825
二、安装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在该目录下。
(另外参考http://bbs.csdn.net/topics/390406501解决方案,我是这样解决的)
gcc -o test test.c -lmysqlclient -I/usr/include/mysql/
执行:
./test
例子
自我感觉:例子封装不好,做成数据库封装:例如传递 MYSQL ROW等 做为函数参数,并且传递指针
具体封装内容待定!!
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
使用的前提是创建表的时候TYPE=INNODB
#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
- linux C mysql 编程
- linux c mysql例子
- linux mysql c 编程
- linux mysql c
- linux c mysql 开发
- Linux C访问MySQL
- linux c mysql demo
- Linux C Mysql Options
- C mySQL编程 linux
- linux c 访问mysql
- linux c mysql 开发
- linux C sqlite3 mysql
- linux c mysql
- Linux C 连接mysql
- Linux C操作mysql
- linux 使用c 连接mysql
- Linux C MySQL数据库函数
- Linux C MySQL数据库函数
- iOS开发 粗解UIDynamicAnimator
- Spider based on scrapy
- 常用软件序列号
- 0020回文的一种实现方法
- git tag的用法
- linux c mysql
- HDU 1114 Piggy-Bank(完全背包问题)
- 错误笔记
- 总结iOS 多线程学习过程六
- 笔记六(脉冲运动)
- 使用stat()函数判断文件类型
- 文件输入和输出流
- HTML5中新表单元素及表单验证
- poj1155 TELE(树形dp+背包)