三层结构图像存取?(100分)

  • 主题发起人 主题发起人 7030
  • 开始时间 开始时间
7

7030

Unregistered / Unconfirmed
GUEST, unregistred user!
在一个三层结构中(bde(tquery)+sql server7.0),我在保存图像时发生了一个怪问题,
显示时图像变形了,而在二层结构中却是正常的,代码如下:
//cds:tclientdataset;
procedure ttedit;
begin
cds.close;
cds.commandtext:='insert into tabel(a) values(:a)';
cds.params.createparam(ftblob,'a',ptinput);
cds.params.parambyname('a').assign(image1.picture.bitmap);
cds.execute;
cds.params.clear;
end;

可保存进去的图像读出来的时候却不正常了!但用tquery却没问题了.
请问各位大侠如何解决?
 
应用服务器的option 的allowcommandtext设置为true了吗?
 
将BDE的BLOB SIZE设置大一些就可以了。我一般将它设成8192
 
to djdsz:
我保存的是小图标,小于32K.
 
没人回答吗?
 
你不用CommandText试试看。

Appserver上查询的SQL语句:select * from tabname where.....

客户端:
cds.edit;
TBlobField(cds.fieldbyname('a')).assign(image1.picture.bitmap);//图标吗,应该是Icon吧
cds.post;
cds.applyupdates(-1);
 
to djdsz:
这个我也试过了,有如下问题:
如果应用服务器的tdatasetprovider的resolvetodataset=true则
数据库保存不进去,如果为false 则会发生一个错误码:远程过程调用失败!
 
不会的啊,你的数据库系统用的是什么?Appserver中你的Dataset是不是设为Active=true了的
 
你可以用你的Tclientdataset 在中间层对应一个TTable控件,然后使用TBlobField
中的loadfromfile方法将二进制数据存入数据库中。
 
to jianggone:
这我试过了,好象也不行啊!文件存进去之后会"矢真"!
 
这个我以前也碰到过,这是由BDE的BLOB SIZE太小引起的,
设置为1024可以解决问题。
 
问题解决了没有!!!?>>>??
....唱!
 
多人接受答案了。
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
I
回复
0
查看
649
import
I
后退
顶部