中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: c访问mysql的blob字段 上一主题 | 下一主题
wfnic
新手上路





积分 6
发帖 2
注册 2008-11-12
状态 离线
『楼 主』:  c访问mysql的blob字段

win2k mysql-4.0.5 devc-4.9通过
#include<windows.h>
#include<string.h>
#include<stdio.h>
#include<stdlib.h>
#include<fcntl.h>
#include<io.h>
#include<mysql.h>
int main(void)
{
unsigned long result,r,len1,i;
unsigned long *t;
MYSQL mysql;// need a instance to init   
MYSQL_RES *res;
MYSQL_ROW row;
MYSQL_FIELD *field;
char *qs,*hout,*query;

if((qs=getenv("QUERY_STRING"))!=NULL) {
strcpy(query,"select body from jdbctest.mess_body where id=");
len1=strlen(query);
for(i=0;qs[i]!='\0';i++)
query[len1+i]=qs[i];

}
else {query="select body from jdbctest.mess_body where id=14";}

mysql_init(&mysql);
mysql_real_connect(&mysql,"192.168.1.6", "wfnic", "197809",NULL,3306,NULL,0);
mysql_real_query(&mysql,query,(unsigned int)strlen(query));
res =mysql_store_result(&mysql);
if (res) row = mysql_fetch_row(res);
t = mysql_fetch_lengths(res);
field = mysql_fetch_field(res);
if (IS_BLOB(field->type)){
if (_setmode(_fileno(stdout),_O_BINARY)!=1){
r=t[0];
qs=row[0];

hout="Content-Type: image/jpeg\n\n";
fprintf(stdout,hout);
fwrite(qs,r,1,stdout);

}}else  fprintf(stdout,"Content-Type: text/plain\n\n%s",row[0]);
mysql_free_result(res);
mysql_close(&mysql);
return 0;
}

2008-11-12 02:25
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
wfnic
新手上路





积分 6
发帖 2
注册 2008-11-12
状态 离线
『第 2 楼』:  

网上首发!c访问mysql的blob字段 如果该纪录内容为二进制 一般的办法是不能正常输出 这大大限制了mysql的高效率应用 不过这个程序做cgi应用时 经测试 速度没有同样功能的apache+mod_php快

我的目标是:专做别人做不了的! qq53096035

2008-11-12 02:28
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: