• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

C++Builder/Delphi 通过 ADO 存取Oracle 的 Blob 字段

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
今天报表组的人说CB5里用ADO读取Oracle的Blob字段报错,于是我试了试,还真是这样,错误信息是“数据类型不被支持”。
我又试了试Delphi7,也是一样的错。
我想,BCB/Delphi的ADO是封装过了,会不会是封装得有问题?
于是跑到VB下写了个Demo,居然成功了~看来真的是封装的问题。
看来只有通过OLE直接操纵ADO了,写了段代码,试了试,也成功了
BCB代码如下:
 1 void __fastcall TForm1::Button1Click(TObject *Sender)
 2 {
 3     const AnsiString sql = "SELECT * FROM Table WHERE ROWNUM <= 1";
 4 
 5     Variant Conn;
 6     Variant ResultSet;
 7     Variant ResultField;
 8     Variant Size, Value;
 9 
10     Conn = Variant::CreateObject("adodb.connection");
11     Conn.OlePropertySet("Provider""OraOLEDB.Oracle");
12     Conn.OleFunction("Open""Database""UserName""Password");
13 
14     ResultSet = Variant::CreateObject("adodb.recordset");
15     ResultSet.OleFunction("Open", sql, Conn, 01);
16     ResultField = ResultSet.OlePropertyGet("Fields""FieldNameOrIndex");
17     Size  = ResultField.OlePropertyGet("ActualSize");
18     Value = ResultField.OleFunction("GetChunk", Size);
19 
20     void* Data = NULL;
21     SafeArrayAccessData(Value.parray, &Data);
22     try
23     {
24         TFileStream* Stream = new TFileStream("C:\\blob.txt", fmCreate);
25         try
26         {
27             Stream->Write(Data, Size);
28         } __finally {
29             delete Stream;
30         }
31     } __finally {
32         SafeArrayUnaccessData(Value.parray);
33     }
34 }



鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
matlab手动实现IIR滤波器发布时间:2022-07-18
下一篇:
关于javaweb项目中调用matlab接口导致内存占用高发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap