C语言连接mysql -select
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的更多相关文章
- C语言连接MySql数据库
C语言连接MySql数据库(CodeBlocks) 操作系统:Windows7(32位)编译软件:Code::Blocks 10.05数 据 库:mysql-5.1.62-win32 数据库内的数据: ...
- Windows下用C语言连接Mysql注意问题
原文:Windows下用C语言连接Mysql注意问题 环境是:在VS6.0 安装Mysql后,我们需要相应的头文件以及lib文件,所以安装过程必须是完整安装.否则不会生成include文件夹哦~ 具体 ...
- Linux centos 7/ubantu下: 用 C 语言连接 MySQL数据库
前言:最近用IPC.socket做ATM.聊天项目,考虑到需要用到数据库,所以总结一下centos.ubantu环境下怎么用C语言操作数据库,例如常见的增删改查等! 一.Centos环境安装mysql ...
- c语言连接mysql数据库的实现方法
C语言连接mysql数据库,需要相应的头文件和lib文件,如果你安装Mysql数据库,会在安装目录下找到这些库文件,如果没有安装,也可以在网上找到 我这里也有一份网上找到的:/201205/other ...
- R语言-连接MySQL数据库方法
版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] R语言连接数据库常用的方法有2种: 1.使用R数据库接口 连接MySQL,使用RMySQL包,使用前RMySQL包要先安 ...
- Linux下C语言连接MySQL
本文出自 http://blog.csdn.net/shuangde800 首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-cl ...
- C语言连接mysql -insert-update
C语言连接mysql数据库实现insert语句:数据库:test表:systeminfo CREATE TABLE `systeminfo` ( `id` int(11) NOT NULL AUTO ...
- R语言连接MYSQL
操作系统:centos 6.4 64bit R语言可以使用RMySQL来连接Mysql数据库,直接使用数据库里面的数据生成图像. 这个是RMYSQL的说明: http://cran.r-project ...
- 我的C语言连接Mysql之路
1.安装好mysql 2.要实现C连接数据库,需要安装数据库连接器(即MySQL Connector/C) MySQL Connector/C是一个C语言的client库,这个库是为了实 ...
随机推荐
- linux 创建账户
linux下创建用户 linux下创建用户(一) Linux 系统是一个多用户多任务的分时操作系统,不论什么一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统. ...
- HDU - 1430 魔板 【BFS + 康托展开 + 哈希】
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1430 思路 我刚开始 想到的 就是 康托展开 但是这个题目是 多组输入 即使用 康托展开 也是会T的 ...
- C#转换人民币大写金额
/// <summary> /// 转换人民币大写金额. /// </summary> public class RMBConverter { /// <summary& ...
- 【leetcode刷题笔记】Single Number
题目: Given an array of integers, every element appears twice except for one. Find that single one. No ...
- 《python基础教程(第二版)》学习笔记 字符串(第3章)
<python基础教程(第二版)>学习笔记 字符串(第3章)所有的基本的序列操作(索引,分片,乘法,判断成员资格,求长度,求最大最小值)对字符串也适用.字符串是不可以改变的:格式化输出字符 ...
- 《python基础教程(第二版)》学习笔记 基础部分(第1章)
<python基础教程(第二版)>学习笔记 基础部分(第1章)python常用的IDE:Windows: IDLE(gui), Eclipse+PyDev; Python(command ...
- 在javascript中使用replace
javascript中使用replace功能很强大,不仅可以替换为字符串,还可以利用正则表达式,对匹配到的字符串为所欲为的进行操作,首先我们来了解一下replace的基本语法 定义和用法 replac ...
- WCF寄宿(Host)之自我寄宿(Self-Hosting)简单实例【Windows应用程序宿主】
前言: 以各种应用程序做自我寄宿的宿主原理方法大同小异,故:这儿直接上案例! 步骤一:创建服务契约和服务 1.新建解决方案:添加WCF服务库项目. 2.为了演示,我把自动生成的接口以及实现接口的类删 ...
- Saiku_学习_02_Schema Workbench 开发mdx和模式文件
一.前言 saiku的查询都是通过cube来进行的.因此每当我们要进行一次多维度查询时,都要先修改xml.上传.重启才能生效,不仅效率低,还不利于学习和理解MDX和模式文件. 通过 workbench ...
- 【二叉树的递归】06填充每个节点中的下一个正确的指针【Populating Next Right Pointers in Each Node】
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 给定一个二叉树 struct Tr ...