如何把Variant存入数据库中,然后再读出来呢?

本文详细介绍了在Delphi中如何使用TDataBlock和TDataBlockInterpreter类来处理Variant类型的数据,包括数据的写入、读取、压缩及在数据库和文件流中的应用。

http://www.delphibbs.com/delphibbs/dispq.asp?LID=3331412


来自:lich, 时间:2006-1-17 12:59:27, ID:3331615 | 编辑
Midas 中有相关的代码  
来自:lich, 时间:2006-1-17 13:08:26, ID:3331624 | 编辑
使用  SConnect.pas 中的
TDataBlock

TDataBlockInterpreter  
来自:dujingwei, 时间:2006-1-17 15:18:00, ID:3331804
能具体些吗?  
来自:lich, 时间:2006-1-18 10:13:45, ID:3332636 | 编辑
TDataBlock 封装了数据块,也可以看作是字节数组
而 TDataBlockInterpreter 则可以将 Variant 写入这个数据块
或者从这个数据块中读取
而对你来说,从 TDataBlock 再写入数据库或从数据库中读取
以及从 Stream 中读取或写入,都是很容易的事情
来自:lich, 时间:2006-1-18 12:19:11, ID:3332730 | 编辑
因为 TDataBlockInterpreter 的 ReadVariant 和 WriteVariant 都声明为私有的方法
所以需要对 SConnect 做一点小小的改动
打开 SConnect.pas 另存到当前目录下
将 TDataBlockInterpreter 开头的 private  改为 public
至于调用的方法如下:
procedure TForm1.Button1Click(Sender: TObject);
var
  m, n: Variant;
  da: IDataBlock;
  di: TDataBlockInterpreter;
  fs: TFileStream;
  vs: TVarFlags;
begin
  m := '1234gfsadgfds';
  m := VarArrayCreate([0, 4], varVariant);
  m[0] := 'faslfda';
  m[2] := 'fjlas'+'_32423';
  da := TDataBlock.Create as IDataBlock;
  di := TDataBlockInterpreter.Create(nil, '');
  di.WriteVariant(m, da);
  //将 Variant 写入文件,和写入数据库类似
  fs := TFileStream.Create('var_data.dat', fmCreate);
  fs.CopyFrom(da.Stream, da.Size);
  FreeAndNil(fs);
  //从文件中读取
  fs := TFileStream.Create('var_data.dat', fmOpenRead);
  da.Clear;
  da.Stream.CopyFrom(fs, fs.Size);
  FreeAndNil(fs);
  //还原
  n := di.ReadVariant(vs, da);
  ShowMessage(n[2] + '*' + n[0]);
end;  
来自:dujingwei, 时间:2006-1-18 12:05:54, ID:3332898
多人接受答案了。  
来自:lich, 时间:2006-1-18 12:18:36, ID:3332911 | 编辑
可以再用 zlib 压缩一下, 可能会更节省空间

转载于:https://www.cnblogs.com/railgunman/archive/2010/11/26/1888298.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值