zoukankan      html  css  js  c++  java
  • C++Builder/Delphi 通过 ADO 存取Oracle 的 Blob 字段

    今天报表组的人说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 }


  • 相关阅读:
    C# 如何比较版本号大小
    C#中复制文件夹及文件的两种方法
    C#解压和压缩文件
    C# NPOI 导入与导出Excel文档 兼容xlsx, xls
    c#使用NPOI导出到excel
    C# 把DataGridView控件数据,转成DataTable
    C# 如何为 datagridview 中增加checkbox列
    Mixed Content: The page at 'xxx' was loaded over HTTPS, but requested an insecure resource 'xxx'.
    c# Winform DataGridView 当前单元格失去焦点的有关问题
    Docker的通俗解释
  • 原文地址:https://www.cnblogs.com/sephil/p/ADO_Oracle.html
Copyright © 2011-2022 走看看