存储过程clob
‘壹’ 存储过程如何按行读取CLOB内容
create table test_clob(id integer,info clob);insert into test_clob values(2,'');commit;select * from test_clob;declare vv_buf varchar2(32767);vv_buf1 varchar2(32767);i integer;begin select t.info into vv_buf from test_clob t where t.id = 2; i := 1; while instr(vv_buf,chr(10),i) >= 1 loop vv_buf1 := substr(vv_buf,i,instr(vv_buf,chr(10),i)-i); i := instr(vv_buf,chr(10),i) + 1; dbms_output.put_line('---------------'); dbms_output.put_line(vv_buf1); end loop; if i <> length(vv_buf) then dbms_output.put_line('---------------'); vv_buf1 := substr(vv_buf,i,length(vv_buf)); dbms_output.put_line(vv_buf1); end if;end;不知道这个是否满足。
‘贰’ delphi clob 储存过程
var
BinData: OleVariant;
s: string;
stream: TStringStream;
DataPtr: Pointer;
len: integer;
begin
s := '34343434......';
stream := TStringStream.Create(s);
len := stream.Size;
BinData := VarArrayCreate([0, len-1], varByte);
DataPtr := VarArrayLock(BinData);
try
stream.ReadBuffer(DataPtr^, Len);
sp1.Parameters.CreateParameter('参数1', ftBlob,pdInput, len ,BinData);
finally
VarArrayUnlock(BinData);
end;
end;
没有验证是否可行,仅供参考
‘叁’ 如何用存储过程读取CLOB类型的字段
create or replace procere get_news
as
v_varchar VARCHAR2(1000);
v_start PLS_INTEGER := 1;
v_buffer PLS_INTEGER := 1000;
begin
dbms_output.enable(1000000);
for rec in (select test,name,value from test) loop
FOR i IN 1..CEIL(DBMS_LOB.GETLENGTH(rec.value) / v_buffer) LOOP
dbms_output.put_line('value是CLOB类型,从'||v_start||'起获取:'||DBMS_LOB.SUBSTR(rec.value, v_buffer, v_start));
v_start := v_start + v_buffer;
end loop;
end loop;
end;
‘肆’ 通过数据库链接调用存储过程,入参有clob字段怎么处理
通过数据库链接调用存储过程,入参有clob字段怎么处理
就是类似取出dbms_output.put_line它的东西,只不过不输出。
有参考例子么,什么实现防范都可以
‘伍’ 存储过程 输出函数为clob字段 为什么输出时还出现“ora-06502 字
开发Delphi 2009+Oracle 10g,数据库控件是dbexpress 修改Oracle Clob字段数据要去大一点的书店才有 看样子是处理单字节字符与双字节字符过程出问题
‘陆’ 超过4000字节,用C#怎么存储到CLOB
若要获取 OracleLob 对象,请调用 GetOracleLob 方法。
可以使用如下格式构造值为 NULL 的 OracleLob:
OracleLob myLob = OracleLob.Null;
该技术主要用于测试从服务器返回的 LOB 是否为 NULL,如此示例所示:
if( myLob == OracleLob.Null)
NULL LOB 的行为与零字节 LOB 的相似之处在于,Read 成功并始终返回零字节。
选择一个包含空值的 LOB 列可返回 Null。
必须在获取临时 LOB 之前开始事务。否则,OracleDataReader 将不能获取后面的数据。
还可以通过调用 DBMS_LOB.CREATETEMPORARY 系统存储过程并绑定 LOB 输出参数打开 Oracle 中的临时 LOB。在客户端,临时 LOB 的行为很像基于表的 LOB。例如,要更新临时 LOB,它必须包含在事务中。
下面的 C# 示例阐释如何打开一个临时 LOB。
OracleConnection conn = new OracleConnection( "server=MyServer; integrated security=yes; ");
conn.Open();
OracleTransaction tx = conn.BeginTransaction();
OracleCommand cmd = conn.CreateCommand();
cmd.Transaction = tx;
cmd.CommandText = "declare xx blob; begin dbms_lob.createtemporary(xx, false, 0); :tempblob := xx; end; ";
cmd.Parameters.Add(new OracleParameter( "tempblob ", OracleType.Blob)).Direction = ParameterDirection.Output;
cmd.ExecuteNonQuery();
OracleLob tempLob = (OracleLob)cmd.Parameters[0].Value;
tempLob.BeginBatch(OracleLobOpenMode.ReadWrite);
tempLob.Write(tempbuff,0,tempbuff.Length);
tempLob.EndBatch();
cmd.Parameters.Clear();
cmd.CommandText = "myTable.myProc ";
cmd.CommandType = CommandType.StoredProcere;
cmd.Parameters.Add(new OracleParameter( "ImportDoc ", OracleType.Blob)).Value = tempLob;
cmd.ExecuteNonQuery();
tx.Commit();
‘柒’ 一个关于oracle存储过程的clob问题
v_parse:= xmlparser.newParser();
xmlparser.parserClob(v_parse,clob数据);
xmldom.domdocument
xmldom.domnodelist
‘捌’ 如何在存储过程中正确使用lob
SQLPLUS>set long 100000(还可以更大,只要你的内存足够大,让clob列的数据能存到buffer中)select [clob列名] from 表名