c语言mysql编程杂记

1.Makefile

INCLUDE=/usr/include/mysql/

LIBS=/usr/lib/mysql

all:

gcc-I$(INCLUDE)-L$(LIBS)-lmysqlclientxxx.c-oxxx

clean:

rm-fxxx

2.mysql的头文件和库文件配置

如果mysql是默认安装的,在Makefile里配置

INCLUDE=/usr/include/mysql

LIBS=/usr/lib/mysql

如果mysql是安装到/usr/local/mysql,在Makefile里配置

INCLUDE=/usr/local/mysql/include/mysql

LIBS=/usr/local/mysql/lib/mysql

如果mysql/usr/local/mysql目录,还需要添加一条链接,否则可能出现 “libmysqlclient.so.16:cannotopensharedobjectfile:Nosuchfileordirectory

ln-s/usr/local/mysql/lib/mysql/libmysqlclient.so.16/usr/lib/libmysqlclient.so.16

3.Unknowncolumn'opcode'in'whereclause'

检查sql语句是否写的有误。

4.Commandsoutofsync;youcan'trunthiscommandnow

如果你在你的客户代码中得到Commandsoutofsync;Youcan'trunthis commandnow,你正在以错误的次序调用客户函数

我在代码里为了获取结果的行数,使用如下语句报的这个错误

mysql_real_query(mysql,sql,strlen(sql));

num=mysql_affected_rows(mysql);

后来我把语句改成如下就可以了

mysql_real_query(mysql,sql,strlen(sql));

rs=mysql_store_result(mysql);

num=mysql_num_rows(rs);

5.Mysql将查询结果放到另一张表里

首先得建好另一张表,然后

insertintonew_tableselectxxx,xxx,xxxfromold_tablewherexxx;

6.取查询结果

MYSQL*mysql;

MYSQL_RES*rs;

MYSQL_ROWrow;

char*sql="selectuid,unamefromuserswhereuid=xxx";

mysql_real_connect(mysql,sql,strlen(sql);

rs=mysql_store_result(mysql);

row=mysql_fetch_row(rs);

结果就存放在row中,row[0]row[1]分别是uiduname,可以使用

atoi或者atol将结果转化成整数。

7.运行时出现“浮点数例外”

出现这个是因为代码中有除0,检查代码对除数为0进行判断。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值