c语言 连接 mysql,C语言连接mysql -select

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

/* select.c */

#include

#include

#include

#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

printf("%s\n",arry[i]);

printf("\n");

while((sqlrow=mysql_fetch_row(res_ptr))) //mysql_fetch_row() 函数从结果集中取得一行作为数字数组

{

;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数据库

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库,这个库是为了实 ...

随机推荐

Xdebug文档(二)变量显示特性

Xdebug能替代PHP的var_dump()函数来显示变量值.xdebug的版本包含对不同数据类型作数组元素/对象属性.最大深度和字符串长度以不同颜色标识.这里也有一些功能能很好地处理变量显示. 相 ...

jquery学习——选择器

一.基础选择 1.$("*") 选择所有元素 2.$(".class") 选择某个类 3.$("#id") 选择某个id 4.$(&quot ...

HDU4745 - Two Rabbits(区间DP)

题目大意 给出一个长度为n的环状序列,两只兔子各自从一个点出发,一个顺时针跳,一个逆时针跳,每个时刻都要求两只兔子所在的数字是相同的,兔子最多跳一个圈~~~问兔子们最多能跳多少次 题解 一个逆时针跳, ...

【转载】ASP.NET MVC的过滤器【Filters】

文章来自: http://www.cnblogs.com/HopeGi/p/3342083.html 这篇对Filters讲的很详细.正好我自己也不用写了,真的很棒的一篇文章 APS.NET MVC中 ...

nth-child与nth-of-type区别

示例详细理解:nth-child(n)与:nth-of-type(n)区别 childselector:nth-child(index) 1,子选择器(childselector,这里是p选择器)选中 ...

Servlet WebSocket的简易聊天室

添加依赖 javax.websocket < ...

storm中worker、executor、task之间的关系

这里做一些补充: worker是一个进程,由supervisor启动,并只负责处理一个topology,所以不会同时处理多个topology. executor是一个线程,由worker启动,是运行t ...

基于聚类的&OpenCurlyDoubleQuote;图像分割”&lpar;python&rpar;

基于聚类的“图像分割” 参考网站: https://zhuanlan.zhihu.com/p/27365576 昨天萌新使用的是PIL这个库,今天发现机器学习也可以这样玩. 视频地址Python机器学 ...

Objective-C&lowbar;Block

一.Block语法 Block:块语法,本质上是匿名函数(没有名称的函数),Block变量存放函数的实现,通过Block变量能直接调⽤函数.标准C里面没有Block.C语言的后期扩展版本号.加⼊了匿名 ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值