Mysql的C语言API进行数据库编程

数据编程基础知识,掌握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-栏位的型态
          unsigned1表示栏位为无记号(unsigned)
          zerofill-1表示栏位被零填满(zero-filled)

四、断开连接
直接调用函数 mysql_close(MYSQL* pmysql);

更多接口函数请访问:http://blog.csdn.net/gexiaobaohelloworld/article/details/9341021

你可能感兴趣的:(编程,数据库)