0

一年多以前,我询问了如何在 .Net 程序中读取 DB2 EBCDIC 数据。非常有用的答案包括读取 VARCHAR 列的例程。

我现在面临阅读 CLOB 专栏。

它们的内部结构是否相似,第一个单词包含实际大小?或者是整个词,考虑到 CLOB 的可能长度要大得多?

谢谢!

4

2 回答 2

0

不是大型机而是 DB2/400(中型)似乎在表本身的外部存储 CLOB 字段:

CREATE TABLE QTEMP/T1 (F1 CLOB(512))
INSERT INTO QTEMP/T1 (F1) VALUES ('TEST')

SELECT * FROM QTEMP/T1

F1
*POINTER

DSPPFM QTEMP/T1

* . . .  + . . .  . 1 . .  . . + .  . . . 2  . . . .  + . . .  . 3 . .
00000000 00000000 00000000 00000000 5CD7D6C9 D5E3C5D9 40404040 40404040

*...+....1....+....2....+....3..
*POINTER

您没有使用DB/2 驱动程序访问数据库来处理所有这些细节是否有任何特殊原因?这就像通过尝试解析 .MDF 文件从 SQL Server 读取。


请参阅IBM 红皮书 | 使用 DB2 for z/OS 和 OS/390 的大型对象第 4.4.1 章LOB 表空间组织以获取更多信息。

于 2012-06-25T23:14:06.627 回答
-2

这是有关如何执行此操作的更详细说明http://ripalsoni.wordpress.com/2008/07/24/how-do-i-read-write-oracle-clob-data-in-aspnet-or- VB网/

第 1 步:添加引用 – Oracle.Dataaccess.dll(在 ODP.NET 中找到)

第 2 步:导入以下命名空间

    Imports Oracle.DataAccess.Client
    Imports Oracle.DataAccess.Types

第 3 步:创建连接字符串

    Public ReadOnly connectionstring = "data source = oradb;user id = rmsoni;password=rmsoni99"

第 4 步:创建以下公共方法

Public Sub ReadLOBData()
Dim con As New OracleConnection(connectionstring)
con.Open()
Dim sql As String = "select CLOBTEXTFIELD from TestCLOB where ID=1"
Dim cmd As OracleCommand = New OracleCommand(sql, con)
Dim dr As OracleDataReader = cmd.ExecuteReader()
dr.Read()
Dim blob As OracleClob = dr.GetOracleClob(0)
txtOutput.Text = blob.Value()
blob.Close()
dr.Close()
con.Close()
End Sub

完整的源代码——</p>

Public Sub WriteLOBData()
Dim connection As New OracleConnection(connectionstring)
connection.Open()

Dim strSQL As String = "INSERT INTO TestCLOB (ID,CLOBTEXTFIELD) VALUES (1,:TEXT_DATA) "
Dim paramData As New OracleParameter
paramData.Direction = ParameterDirection.Input
paramData.OracleDbType = OracleDbType.Clob
paramData.ParameterName = "TEXT_DATA"
paramData.Value = txtInput.Text

Dim cmd As New OracleCommand
cmd.Connection = connection
cmd.Parameters.Add(paramData)
cmd.CommandText = strSQL
cmd.ExecuteNonQuery()

paramData = Nothing
cmd = Nothing
connection.Close()
End Sub
于 2012-06-25T21:35:49.623 回答