提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:郝浩|2013-05-02 16:53:25.000|阅读 284 次
概述:dotConnect for Oracle可以使用用户自定义类型,由于在Oracle数据库中提供机制使用类型化和非类型化的oracleobjects。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
dotConnect for Oracle可以使用用户自定义类型,由于在Oracle数据库中提供机制使用类型化和非类型化的oracleobjects。
非类型化的OracleObjects是由OracleObject类实例表示。这是一种处理Oracle对象灵活的机制,但是却不能够类型验证,同时比起使用类型化OracleObjects.而言,也不是很便捷。
类型化oracleobject代表单一的用户定义类型,允许像普通的.NET对象一样使用实例。本文主要是讲解如何创建和使用类型化的OracleObjects。值得注意的是,类型化和无类型化的OracleObjects都可以在OCI模式下使用。
现在需要用户定义的类型TAddress,和一张有在你的Oracle 数据库中创建的TAddress类型字段的表EmpObject,这个可以通过下面的代码实现:
CREATE TYPE TAddress AS OBJECT ( Country VARCHAR2(30), City VARCHAR2(30), Street VARCHAR2(30), Apartment NUMBER ); / CREATE TABLE EmpObject ( Code NUMBER PRIMARY KEY, Person VARCHAR2(40), Address TADDRESS, Job VARCHAR2(9) ); / INSERT INTO EmpObject (Code, Person, Address, Job) VALUES (1, 'SMITH', TAddress('UK', 'London', 'Street', 12), 'CLERK'); INSERT INTO EmpObject (Code, Person, Address, Job) VALUES (2, 'JONES', TAddress('USA', 'New York', 'Street', 418), 'MANAGER'); INSERT INTO EmpObject (Code, Person, Address, Job) VALUES (3, 'SCOTT', TAddress('CANADA', 'Ottawa', 'Street', 26),'PRESIDENT'); INSERT INTO EmpObject (Code, Person, Address, Job) VALUES (4, 'MARTIN', TAddress('FRANCE', 'Paris', 'Street', 162), 'ANALYST');
创建类型化OracleObjects
要创建一个类型化的OracleObject ,可以执行下列步骤:
1、启动类型化Oracle对象向导:在vs的主菜单中选择Tools -> Oracle -> Oracle Objects。
2、将连接属性设置到你创建对象类型化的服务器上,然后点击“下一步”:
注意在OCI模式下使用连接,主要是因为Oracle对象在直接模式下不可用。
3、选择你想要的类型并单击“下一步”。在此示例中, 使用的是TAddress类型:
4、设置生成的类的名称、命名空间的放置、对象的命名规则。示例中选择的是默认值。
导航将会生成用于展示TAddress对象类型的TAddress类。
使用类型化的OracleObjects
通过产生的的类型OracleObject类,Oracle UDTs的属性就可以像通常的.NET对象一样使用。下面来看看如何使用Taddress实例,代码如下所示:
C#
// Create and open a connection. Connection should not be in Direct mode, // as in this case Oracle Objects would be unavailable. OracleConnection connection = new OracleConnection ("Server = Ora; User Id = Scott; Password = tiger; Direct = false;"); connection.Open(); // Create a command selecting all rows from the table EmpObject OracleCommand command = new OracleCommand ("select * from empobject", connection); // By default, all Oracle Objects are retrieved by the application as instances // of the OracleObject class. Thus, to use typed OracleObjects, we need to set // the mapping from the TADDRESS Oracle UDT to Taddress class used in the application. OracleType.GetObjectType("TAddress", connection).UdtType = typeof(TAddress); // Execute the command, retrieve the data reader and print the table content. OracleDataReader r = command.ExecuteReader(); while (r.Read()) { TAddress addr = (Taddress)r["Address"]; Console.WriteLine (r["Person"].ToString() + ": " + addr.Country + ", " + addr.City + ", " + addr.Street + " " + addr.Apartment); }
[Visual Basic]
Create and open a connection. Connection should not be in Direct mode, ' as in this case Oracle Objects are unavailable. Dim connection = New OracleConnection( _ "Server = Ora; User Id = Scott; Password = tiger; Direct = false;") connection.Open() ' Create a command selecting all rows from the table EmpObject Dim command = New OracleCommand ("select * from empobject", connection) ' By default, all Oracle Objects are retrieved by the application as instances ' of the OracleObject class. Thus, to use typed OracleObjects, we need to set ' the mapping from the TADDRESS Oracle UDT to Taddress class used in the application. OracleType.GetObjectType("TAddress", connection).UdtType = GetType(TAddress) ' Execute the command, retrieve the data reader and print the table content. Dim r As OracleDataReader = command.ExecuteReader() While (r.Read()) Dim addr As Taddress = r("Address") Console.WriteLine( _ r("Person").ToString() + ": " + addr.Country + ", " + _ addr.City + ", " + addr.Street + " " + addr.Apartment.ToString()) End While
下一个示例是使用Taddress类的参数更新了EmpObject表,代码如下所示:
[C#]
// Create an UPDATE command with parameter OracleCommand command = new OracleCommand ("update empobject set address = :pAddress where code = 1", connection); // Create and set a Taddress object Taddress addr = new Taddress(); addr.Country = "USA"; addr.City = "New York"; addr.Street = "Street"; addr.Apartment = 418; // Set up the command parameter. OracleParameter param = new OracleParameter("pAddress", OracleDbType.Object, "TAddress"); param.Value = addr; command.Parameters.Add(param); // Execute the command. command.ExecuteNonQuery();
[Visual Basic]
Create an UPDATE command with parameter Dim command = New OracleCommand( _ "update empobject set address = :pAddress where code = 1", connection) ' Create and set a Taddress object Dim addr As Taddress = New Taddress() addr.Country = "USA" addr.City = "New York" addr.Street = "Street" addr.Apartment = 418 ' Set up the command parameter. Dim param = New OracleParameter("pAddress", OracleDbType.Object, "TAddress") param.Value = addr command.Parameters.Add(param) ' Execute the command. command.ExecuteNonQuery()
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@capbkgr.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@capbkgr.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢