c语言sqlserver数据库头文件,Mysql的C语言API进行数据库编程

数据编程基础知识,掌握C语言,熟悉简单的SQL语句,能够实现简单的增、删、查、改即INSERT、DELETE 、SELECT、UPDATE语句,其中SELECT语句尤为重要,面试笔试中经常被问及。默认都懂的SQL语言,mysql数据库在不同的系统下包含的头文件也不同windows下加以下头文件:

#include//因为数据库通信用的socket技术

#include //加mysql.h文件所在的路径

linux下加:#include

并且在链接的时候要加-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

{

row=mysql_fetch_row(result);//显示每一行

for(j=0;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

{

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);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值