C语言实现查询mysql数据库的行数,列的属性,以及每条记录。

 /* select.c */
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include "/usr/include/mysql/mysql.h"
 int main(int argc, char *argv[])
 {
     MYSQL my_connection;
     MYSQL_RES *res_ptr;   /*指向检索的结果存放地址的指针*/
     MYSQL_ROW sqlrow;     /*返回的记录信息*/
     MYSQL_FIELD *fd;      /*字段结构指针*/
     ][];       /*用来存放各字段名*/
     int res;              /*执行查询操作后的返回标志*/
     int i,j,k;
     mysql_init(&my_connection);
     /*mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)*/
     ,NULL,CLIENT_FOUND_ROWS))
     {
         printf("Connection successn !\n");
         res = mysql_query(&my_connection, "select * from systeminfo");  //mysql_connect() 函数来建立一个连接并使用之
         if (res)
         {
             printf("SELECT error:%sn",mysql_error(&my_connection));    //mysql_error() 函数返回上一个 MySQL 操作产生的文本错误信息
         }
         else
         {
             res_ptr=mysql_store_result(&my_connection);   //mysql_store_result()得到result是存下来的,你无需把全部行结果读完,就可以进行另外的查询
             if(res_ptr)
             {
                 printf("Retrieved %lu Rowsn \n",(unsigned long)mysql_num_rows(res_ptr));  //mysql_num_rows() 函数返回结果集中行的数目
                 /*取得各字段名*/
                 ;fd=mysql_fetch_field(res_ptr);i++)   //mysql_fetch_field() 函数从结果集中取得列信息并作为对象返回
                     strcpy(arry[i],fd->name);
                 /*输出各条记录*/
                 printf("下面是检索出的各条记录信息:\n");
                 j=mysql_num_fields(res_ptr);    //mysql_num_fields() 函数返回结果集中字段的数
                 ;i<j;i++)
                     printf("%s\n",arry[i]);
                 printf("\n");
                 while((sqlrow=mysql_fetch_row(res_ptr)))  //mysql_fetch_row() 函数从结果集中取得一行作为数字数组
                 {
                     ;i<j;i++)
                         printf("%s\n",sqlrow[i]);
                     printf("\n");
                 }
                 if (mysql_errno(&my_connection))
                 {
                     fprintf(stderr,"Retrive error:%s \n",mysql_error(&my_connection));
                 }
             }
             mysql_free_result(res_ptr);  //在脚本结束后所有关联的内存都会被自动释放
         }
         mysql_close(&my_connection);
     }
     else
     {
         fprintf(stderr, "Connection failedn");
         if (mysql_errno(&my_connection))   //mysql_errno() 来提取错误代码
         {
             fprintf(stderr, "Connection error %d: %s\n",mysql_errno(&my_connection),mysql_error(&my_connection));
         }
     }
     return EXIT_SUCCESS;
 } 

select.c

编译时添加-L/usr/lib64/mysql -lmysqlclient 参数
    #  gcc select.c -L/usr/lib64/mysql -lmysqlclient -o select

mysql_fetch_field()返回表的属性
{  

  name - 列名
  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,如果该列是 numeric
  blob - 1,如果该列是 BLOB
  type - 该列的类型
  unsigned - 1,如果该列是无符号数
  zerofill - 1,如果该列是 zero-filled

}

C语言连接mysql -select的更多相关文章

  1. C语言连接MySql数据库

    C语言连接MySql数据库(CodeBlocks) 操作系统:Windows7(32位)编译软件:Code::Blocks 10.05数 据 库:mysql-5.1.62-win32 数据库内的数据: ...

  2. Windows下用C语言连接Mysql注意问题

    原文:Windows下用C语言连接Mysql注意问题 环境是:在VS6.0 安装Mysql后,我们需要相应的头文件以及lib文件,所以安装过程必须是完整安装.否则不会生成include文件夹哦~ 具体 ...

  3. Linux centos 7/ubantu下: 用 C 语言连接 MySQL数据库

    前言:最近用IPC.socket做ATM.聊天项目,考虑到需要用到数据库,所以总结一下centos.ubantu环境下怎么用C语言操作数据库,例如常见的增删改查等! 一.Centos环境安装mysql ...

  4. c语言连接mysql数据库的实现方法

    C语言连接mysql数据库,需要相应的头文件和lib文件,如果你安装Mysql数据库,会在安装目录下找到这些库文件,如果没有安装,也可以在网上找到 我这里也有一份网上找到的:/201205/other ...

  5. R语言-连接MySQL数据库方法

    版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[+]   R语言连接数据库常用的方法有2种: 1.使用R数据库接口 连接MySQL,使用RMySQL包,使用前RMySQL包要先安 ...

  6. Linux下C语言连接MySQL

    本文出自   http://blog.csdn.net/shuangde800 首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-cl ...

  7. C语言连接mysql -insert-update

    C语言连接mysql数据库实现insert语句:数据库:test表:systeminfo CREATE TABLE `systeminfo` (  `id` int(11) NOT NULL AUTO ...

  8. R语言连接MYSQL

    操作系统:centos 6.4 64bit R语言可以使用RMySQL来连接Mysql数据库,直接使用数据库里面的数据生成图像. 这个是RMYSQL的说明: http://cran.r-project ...

  9. 我的C语言连接Mysql之路

    1.安装好mysql     2.要实现C连接数据库,需要安装数据库连接器(即MySQL Connector/C)    MySQL Connector/C是一个C语言的client库,这个库是为了实 ...

随机推荐

  1. Django——auth用户认证

    之前我们在进行用户校验的时候,总是从数据库中获取数据,然后再进行对比,就像如下这样: def login(request): if request.method == "POST" ...

  2. MyBatis:学习笔记(4)——动态SQL

    MyBatis:学习笔记(4)——动态SQL 如果使用JDBC或者其他框架,很多时候需要你根据需求手动拼装SQL语句,这是一件非常麻烦的事情.MyBatis提供了对SQL语句动态的组装能力,而且他只有 ...

  3. python微信库 --- itchat

    python实现微信接口——itchat模块 安装 pip install itchat 登录 itchat.auto_login() # 这种方法将会通过微信扫描二维码登录,但是这种登录的方式确实短 ...

  4. 配置asp.net IIS服务器遇到的问题以及详细图例解决方案

    原来配置过IIS服务,但是没有将自己的程序放在IIS服务器上,今天突发奇想,看看自己写的程序怎么样啊,能否在服务器上运行一下,说干就干,但是遇到了很多困难,今天把陪孩子过程以及遇到的问题给大家说说,希 ...

  5. LintCode:链表操作(合并与反转)

    描述: (1)翻转一个链表 样例 给出一个链表1->2->3->null,这个翻转后的链表为3->2->1->null ********************** ...

  6. uCGUI 按键窗口切换机制

    前段时间在做一个窗口项目,这个项目菜单项过多,在管理起来比较麻烦.想做一个高效移植又方便的一个切换机制.后来在网上多方查找这方面资料,但是感觉比较少.后来自己整理出了这个结构,希望对后来朋友有所帮助. ...

  7. poj 1144 Network 【求一个网络的割点的个数 矩阵建图+模板应用】

    题目地址:http://poj.org/problem?id=1144 题目:输入一个n,代表有n个节点(如果n==0就结束程序运行). 在当下n的这一组数据,可能会有若干行数据,每行先输入一个节点a ...

  8. org.eclipse.core.resources.bak文件导致MyEclipse每次关闭时无法保存文件

    MyEclipse关闭时提示如下信息 Problems occurred while trying to save the state of the workbench. Internal Error ...

  9. Codeforces 876C Classroom Watch:枚举

    题目链接:http://codeforces.com/contest/876/problem/C 题意: 定义函数:f(x) = x + 十进制下x各位上的数字之和 给你f(x)的值(f(x) < ...

  10. jQuery应用之eraser.js使用,实现擦除、刮刮卡效果

    jquery.eraser是一款使用鼠标或触摸的动作来擦除画布显示真正图片的插件.jquery.eraser插件的原理是用一个画布遮住图片,然后根据触摸或鼠标输入来擦除画布显示图片,您可以在参数中指定 ...