提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:郝浩|2013-05-08 11:04:29.000|阅读 609 次
概述:dotConnect for Oracle中的LOB是一种数据类型,主要用于存储大对象。在Oracle中存在三种LOB数据类型分别是BLOB、CLOB和DBCLOB,今天主要来看一下这个BLOB和CLOB类型。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
LOB基本概念:
LOB是一种数据类型,主要用于存储大对象。在Oracle中存在三种LOB数据类型分别是BLOB:Binary Large Object、CLOB:Character Large Object、DBCLOB:Double-byte Character Large Object,今天主要来看一下这个BLOB和CLOB类型。
BLOB 数据的使用
二进制数据一般都会表现为字节流或是缓冲区。dotConnect for Oracle允许用最方便的方式操纵BLOB数据。你可以使用OracleLob。值属性或使用OracleLob.Read()和OracleLob.Write()方法来传输数据到或是来自服务器,两种方法下面都有雨示例。值得注意的是当OracleLob.LobType属性是OracleDbType.Blob时,这个OracleLob.Value被视为字节数组,OracleDbType.Clob以及OracleDbType.NClob将会被一字符串视为OracleLob.Value。
下一个示例程序显示如何从硬盘上传文件到服务器以及下载下来。要执行这些程序,你必须创建一个表,如下:
CREATE TABLE PICTURES (
ID NUMBER(12),
PICNAME VARCHAR2(20),
PICTURE BLOB
)
[C#]
static void UploadBlob(OracleConnection myConnection) { //Open file on disk FileStream fs = new FileStream("D:\\Tmp\\test.bmp", FileMode.Open, FileAccess.Read); BinaryReader r = new BinaryReader(fs); myConnection.Open(); //Create temporary BLOB OracleLob myLob = new OracleLob(myConnection,OracleDbType.Blob); int streamLength = (int)fs.Length; //Transfer data to server myLob.Write(r.ReadBytes(streamLength), 0, streamLength); //Perform INSERT OracleCommand myCommand = new OracleCommand( "INSERT INTO Pictures (ID, PicName, Picture) VALUES(1,'pict1',:Pictures)", myConnection); OracleParameter myParam = myCommand.Parameters.Add("Pictures", OracleDbType.Blob); myParam.OracleValue = myLob; try { Console.WriteLine(myCommand.ExecuteNonQuery() + " rows affected."); } finally { myConnection.Close(); r.Close(); fs.Close(); } } static void DownloadBlob(OracleConnection myConnection) { OracleCommand myCommand = new OracleCommand("SELECT * FROM Pictures", myConnection); myConnection.Open(); OracleDataReader myReader = myCommand.ExecuteReader(System.Data.CommandBehavior.Default); try { while (myReader.Read()) { //Obtain OracleLob directly from OracleDataReader OracleLob myLob = myReader.GetOracleLob(myReader.GetOrdinal("Picture")); if (!myLob.IsNull) { string FN = myReader.GetString(myReader.GetOrdinal("PicName")); //Create file on disk FileStream fs = new FileStream("D:\\Tmp\\" + FN + ".bmp", FileMode.Create); //Use buffer to transfer data byte[] b = new byte[myLob.Length]; //Read data from database myLob.Read(b,0,(int)myLob.Length); //Write data to file fs.Write(b,0,(int)myLob.Length); fs.Close(); Console.WriteLine(FN + " downloaded."); } } } finally { myReader.Close(); myConnection.Close(); } }
[Visual Basic]
Public Sub UploadBlob(ByVal myConnection As OracleConnection) 'Open file on disk Dim fs As FileStream = New FileStream("D:\Tmp\test.bmp", FileMode.Open, FileAccess.Read) Dim r As BinaryReader = New BinaryReader(fs) myConnection.Open() 'Create temporary BLOB Dim myLob As OracleLob = New OracleLob(myConnection, OracleDbType.Blob) Dim streamLength As Int32 = fs.Length 'Transfer data to server myLob.Write(r.ReadBytes(streamLength), 0, streamLength) 'Perform INSERT Dim myCommand As OracleCommand = New OracleCommand( "INSERT INTO Pictures (ID, PicName, Picture) VALUES(1,'pict1',:Pictures)", myConnection) Dim myParam As OracleParameter = myCommand.Parameters.Add("Pictures", OracleDbType.Blob) myParam.OracleValue = myLob Try Console.WriteLine(myCommand.ExecuteNonQuery() & " rows affected.") Finally myConnection.Close() r.Close() fs.Close() End Try End Sub Public Sub DownloadBlob(ByVal myConnection As OracleConnection) Dim myCommand As New OracleCommand("SELECT * FROM Pictures", myConnection) myConnection.Open() Dim myReader As OracleDataReader = & _ myCommand.ExecuteReader(System.Data.CommandBehavior.Default) Try While myReader.Read() Dim myLob As OracleLob = myReader.GetOracleLob(myReader.GetOrdinal("Picture")) If Not myLob.IsNull Then Dim FN As String = myReader.GetString(myReader.GetOrdinal("PicName")) Dim fs As FileStream = New FileStream("D:\Tmp\" + FN + ".bmp", FileMode.Create) Dim w As BinaryWriter = New BinaryWriter(fs) w.Write(myLob.Value) w.Close() fs.Close() Console.WriteLine(String.Concat(FN, " downloaded.")) End If End While Finally myReader.Close() myConnection.Close() End Try End Sub
CLOB 数据使用
CLOB 数据的使用和BLOB数据是一样的,区别就在于Value属性的表现。当从OracleLob.Value读取时,CLOB和NCLO数据类型,会得到字符串。数据是透明的解码,所以你不必担心字符集。如果需要原始数据,可以使用 OracleLob的里流媒体功能,那是OracleLob.Read 和OracleLob.Write的方法。请注意,由于OracleLob.Value是一个只读属性,你可以只用OracleLob.Write方法将数据写入到的LOB中,但是并没有执行编码。
For example consider this table definition.
CREATE TABLE ClobTable (
Id NUMBER,
Name VARCHAR2(30),
Value CLOB
)
如果您需要执行简单的任务,如获取记录集,在大多数情况下,你不需要知道oraclelob。当在fetch 上调用OracleDataReader.GetValue时,将会得到一组字节用于BLOB列以及用于CLOB one的字符串。此外你可以使用OracleDataReader.GetChars、 OracleDataReader.GetBytes得到LOB值块。示例如下:
[C#]
... OracleCommand oraCommand = new OracleCommand("SELECT * FROM ClobTable", oraConnection); OracleDataReader reader = oraCommand.ExecuteReader(); while (reader.Read()) Console.WriteLine(reader.GetValue(2)); ...
[Visual Basic]
... Dim oraCommand As OracleCommand = new OracleCommand( _ "SELECT * FROM ClobTable", oraConnection) Dim reader As OracleDataReader = oraCommand.ExecuteReader() while (reader.Read()) Console.WriteLine(reader.GetValue(2)) end while ...
使用OracleLob对象也可以达到一样的效果:
[C#]
... OracleCommand oraCommand = new OracleCommand("SELECT * FROM ClobTable", oraConnection); OracleDataReader reader = oraCommand.ExecuteReader(); OracleLob clob; while (reader.Read()) { clob = reader.GetOracleLob(2); Console.WriteLine(clob.Value); } ...
[Visual Basic]
... Dim oraCommand As OracleCommand = new OracleCommand( _ "SELECT * FROM ClobTable", oraConnection) Dim reader As OracleDataReader = oraCommand.ExecuteReader() Dim clob As OracleLob while (reader.Read()) clob = reader.GetOracleLob(2) Console.WriteLine(clob.Value) end while ...
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
文章转载自:慧都控件本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
dotConnect for Oracle不仅可以高效地连接到Oracle数据库,还提供了新的开发工具和技术。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢