数据编程基础知识,掌握C语言,熟悉简单的SQL语句,能够实现简单的增、删、查、改即INSERT、DELETE 、SELECT、UPDATE语句,其中SELECT语句尤为重要,面试笔试中经常被问及。默认都懂的SQL语言,mysql数据库在不同的系统下包含的头文件也不同windows下加以下头文件:
#include<windows.h>//因为数据库通信用的socket技术
#include <C:/mysql/include/mysql.h>//加mysql.h文件所在的路径
linux下加:#include<mysql/mysql.h>
并且在链接的时候要加-lmysqlclient选项意思是链接到libmysqlclient.so这个库文件
数据库编程的步骤:
1.初始化client;
2.client和server建立连接
3.接收发送(client向server发送SQL语句,server将执行SQL语句的结果返回给client)
4.断开连接;
一、初始化client;
通过调用函数MYSQL* mysql_init( MYSQL *Pmysql)函数来实现
MYSQL*封装好的结构指针,该函数的传入参数通常为NULL即可,返回一个指向新分配的链接句柄结构的指针,失败则返回NULL;
两种常用的方法:
' MYSQL * mysql1;
mysql1=mysql_init(NULL);
或者
MYSQL mysql1;
mysql_init(&mysql1);
'
二、建立连接
建立连接的API是:
函数原型:MYSQL * mysql_real_connect(MYSQL * Pmysql, const char * hostname,const char * usename,const char * passwd, const char * dbname,0,0,0);
使用方法:
‘MYSQL* connection;
connection = mysql_real_connect(&mysql1,“localhost”, "dbuser1", "dbuser1", "db1", 0, 0, 0);
//连接时需要那本机做实验即先连接localhost即127.0.0.1,待连接成功后再改为要连接的数据库所在服务器的IP地址,第三个参数表示用户名,第四个表示用户对应的密码,第五个参数表示使用的数据库名称。
’
三、连接成功后对数据库进行一系列的操作:
函数:
mysql_query(MYSQL * pmysql, const char * sql )
至少包含一条SQL语句,并且句末不必添加分号分隔符。貌似添加也没影响:
mysql_query(&mysql1, “UPDATE table1 SET name=’张三’ WHERE name=’李四’” )//执行该语句把李四修改为张三
但是这条语句直接写死在程序中,如果要进行其他操作就得重新写代码,很是不方便,于是升级一下,用户输入什么SQL语句就执行什么操作
char name1[1024];
memset(name1,0,sizeof(name1));
read(STDIN_FILENO, name1, sizeof(name1));//从屏幕上读取输入的SQL语句
name1[strlen(name1) - 1] = 0;//去除换行符的影响
char SQL[1024];
memset(SQL, 0, sizeof(SQL));
sprintf(SQL, "UPDATE table1 SET name='%s' WHERE name='%s'", name1, name);//初始化SQL数组
printf("%s\n", SQL);
if (mysql_query(&mysql1, SQL))//执行SQL语句
{
printf("INSERT error: %s", mysql_error(&mysql1));//执行失败打印错误消息;
}
注意:登录数据库后必须设置数据库的字符集否则SQL语句无法执行。
windows下设置字符集为GBK:mysql_query(connection, "SET NAMES GBK");
linux下设置的字符集为UTF8:mysql_query(connection, "SET NAMES utf8");
如果执行select查询语句,如何才能得到查询的结果并显示出来呢?
执行SELECT语句的到的查询的结果:
函数:
`MYSQL_RES * mysql _store_result(MYSQL * Pmysql执行成功则返回一个查询结果的指针,查询无果则返回NULL;
注意:使用该函数到最后一定mysql_free_result(MYSQL_RES *res)//释放相关资源
eg:MYSQL_RES * result = mysql_store_result(&mysql1);
//此函数一定要和执行SQL语句中的SELECT 语句结合使用
查看查询结果中的记录信息:
MYSQL_ROW mysql _fetch _row(MYSQL_RES *result) ;
使用:
int rowcount = mysql_affected_rows(connection);//返回执行SQL语句后有多少行(记录)。
MYSQL_ROW row ;
int i=0;
int j=0;
for(i=0;i<rowcount;i++)
{
row=mysql_fetch_row(result);//显示每一行
for(j=0;j<filecount;j++)
{
printf("%s\t",row[j]);//打印第i行的第j个字段
}
printf("\n");
}
查看查询结果中的字段信息:
使用函数
`:MYSQL_FIELD_ * mysql_fetch_field(MYSQL_RES * result)//接受查询结果的地址作为参数`
int filecount = mysql_field_count(connection);//这个函数返回执行 SQL语句后有多少列
MYSQL_FIELD *filed=NULL;
int i=0;
for(i=0;i<filecount;i++)
{
filed=mysql_fetch_field(result);
printf("%s\t",filed->name);
}
//name 可以根据需要修改
name-栏位名称
table-栏位所在的table名称
max_length-栏位的最大长度
not_null- 1表示栏位不能为空(null)的
primary_key-1表示栏位是主要键(primary key)
unique_key-1表示栏位是唯一键(unique key)
multiple_key-1表示栏位非唯一键(non-unique key)
numeric-1表示栏位为数值的
blob-1表示栏位为BLOB
type-栏位的型态
unsigned-1表示栏位为无记号(unsigned)
zerofill-1表示栏位被零填满(zero-filled)
四、断开连接
直接调用函数 mysql_close(MYSQL* pmysql);
更多接口函数请访问:http://blog.csdn.net/gexiaobaohelloworld/article/details/9341021