彩票走势图

dotConnect for Oracle使用教程:VARRAY类型

原创|使用教程|编辑:郝浩|2013-05-07 11:00:53.000|阅读 269 次

概述:dotConnect for Oracle提供了数组和嵌套表的两种方式:一是填充数据集,在这种情况下,阵列的数据将被存储在单个表中的数据集,将会对表设置一个关联,关联着来自用阵列行的基本选择的一个组。二是得到OracleArray类型的一个对象,并通过索引属性访问项目。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

dotConnect for Oracle提供了数组和嵌套表的两种方式:

  • 填充数据集,在这种情况下,阵列的数据将被存储在单个表中的数据集,将会对表设置一个关联,关联着来自用阵列行的基本选择的一个组。
  • 得到OracleArray类型的一个对象,并通过索引属性访问项目。
If such types are created:
CREATE TYPE TArray1 AS VARRAY (5) OF NUMBER;

CREATE TYPE TArray2 AS VARRAY (4) OF CHAR(10);

CREATE TABLE ArrayTable (
  Code NUMBER,
  Title VARCHAR2(10),
  Arr1 TArray1,
  Arr2 TArray2
);

    在数据集上将会有3个表:ArrayTable、 ArrayTableArr1、ArrayTableArr2。但是用这种方法有一个限制,你不能通过DataAdapter更新方法发布更新的数据到服务器。

    还有一种方法访问来自数组的数据和嵌套表,就是使用OracleArray 和 OracleTable类。比如对于OracleArray类你可以用下面的代码:

[C#]

OracleArray oraArray = dataReader.GetOracleArray(i);
foreach (object obj in oraArray) {
  lbResult.Items.Add(obj.ToString());
}

[Visual Basic]

dim oraArray as OracleArray = dataReader.GetOracleArray(i);
dim obj as object
for each obj in oraArray
  lbResult.Items.Add(obj.ToString())
next

    对于SQL 和PL/SQL语句的参数可以使用VARRAY类型,示例如下:

[C#]

OracleCommand cmd = oracleConnection1.CreateCommand();
cmd.CommandText = "INSERT INTO ArrayTable (CODE, ARR1) VALUES (1, :ARR1)";
cmd.Parameters.Add(new OracleParameter("ARR1", OracleDbType.Array));

OracleArray arr1 = new OracleArray("SCOTT.TARRAY1", oracleConnection1);
arr1.Add(10);
arr1.Add(20);
arr1.Add(30);

cmd.Parameters["ARR1"].Value = arr1;
cmd.ExecuteNonQuery();

[Visual Basic]

dim cmd as OracleCommand = OracleConnection1.CreateCommand()
cmd.CommandText = "INSERT INTO ArrayTable (CODE, ARR1) VALUES (1, :ARR1)"
cmd.Parameters.Add(New OracleParameter("ARR1", OracleDbType.Array))

dim arr1 as OracleArray = new OracleArray("SCOTT.TARRAY1", OracleConnection1)
arr1.Add(10)
arr1.Add(20)
arr1.Add(30)

标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn

文章转载自:慧都控件

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP