数组做为参数传入Oracle存储过程操作数据库
p { margin-bottom: 0.25cm; direction: ltr; color: rgb(0, 0, 0); line-height: 120%; text-align: justify }
p.western { font-family: "Times New Roman", serif; font-size: 10pt }
p.cjk { font-family: "宋体", "SimSun"; font-size: 10pt }
p.ctl { font-family: "Times New Roman", serif; font-size: 10pt }
数组里存储的是String、int、lang等基本数据类型或引用数据类型(不包括java bean)
一、在oracle中定义一个数组类型(TYPE)
代码如下:
createorreplacetype
msg_array astableofnumber;
意思是创建一个名称为msg_array,存放类型为整型的数组类型
二、在oracle中定义一个存储过程
代码如下:
createorreplaceprocedure
modifyage(m_array
in
msg_array)
as
begin
for
i ..m_array.count
loop
update
users set
agewhere
id=m_array(i);
endloop;
commit;
exception
whenothersthen
rollback;
end
modifyage;
操作。
三、JAVA代码如下
Connection
conn = null;
CallableStatement
cstmt = null;
try
{
Class.forName("oracle.jdbc.OracleDriver");
conn
= DriverManager.getConnection(
"jdbc:oracle:thin:@localhost:1521:orcl",
"orcl_dev",
"dev");
List
list = new
ArrayList();
list.add(30);
list.add(31);
list.add(32);
list.add(33);
ArrayDescriptor
tabDesc = ArrayDescriptor.createDescriptor(
"MSG_ARRAY",
conn);
ARRAY
vArray = new
ARRAY(tabDesc, conn, list.toArray());
cstmt
= conn.prepareCall("call
modifyage(?)");
cstmt.setArray(1,
vArray);
cstmt.execute();
cstmt.close();
conn.close();
}
catch
(Exception e) {
e.printStackTrace();
}
个变量,然后通过JDBC的方式得到Connection,然后定义要传给存储过程的数组。
映射
Oracle端数组
AS TABLE OF类型
通过ArrayDescriptor.createDescriptor("MSG_ARRAY",conn)定义数组描述方式。
在通过new
ARRAY(tabDesc, conn,
list.toArray()),把要传入的数组按批定的数组描述方式生成一个新的Oracle定义的数组。
调用存储过程,传入参数并执行。
数组里存储的是java
bean
一、在oracle中定义一个对象类型(OBJECT)
createorreplacetype
userobj asobject(
id
number,
username
),
age
number,
password
)
)
意思是创建一个名称为userobj的对象类型,字符串的类型一定要写成nvarchar2,否则,传入数据库的字符串为null
二、在oracle中定义一个数组类型(TYPE)
代码如下:
createorreplacetype
obj_array astableof
userobj;
意思是创建一个名称为obj_array,存放类型为userobj的数组类型
三、在oracle中定义一个存储过程
代码如下:
createorreplaceprocedure
saveObjArray
(
avc_objArray
in
obj_array,
rowcountoutnumber,
msg
outvarchar2
)as
userinfo
userobj;
begin
for
i in
avc_objArray.First()..avc_objArray.Last()loop
userinfo
:=
avc_objArray(i);
insertinto
users (id,name,password,age)
values(userinfo.id,userinfo.username,userinfo.password,userinfo.age);
endloop;
rowcount:=sql%rowcount;
commit;
exception
whenothersthen
;
msg
:=sqlerrm;
rollback;
end
saveObjArray;
创建一个存储过程,传入的参数是上面定义的obj_array类型的数组,循环数组,分别插入数据库。返回受影响的行数和提式信息。
四、JAVA代码如下
Connection
conn = null;
CallableStatement
cstmt = null;
try{
Class.forName("oracle.jdbc.OracleDriver");
conn
= DriverManager.getConnection(
"jdbc:oracle:thin:@localhost:1521:orcl",
"orcl_dev",
"dev");
List<User>
userList = new
ArrayList<User>();
User
user = new
User();
user.setId(37);
user.setUsername("dddddd");
user.setPassword("dddddd");
user.setAge(14);
userList.add(user);
StructDescriptor
recDesc =
StructDescriptor.createDescriptor("USEROBJ",
conn);
ArrayList<STRUCT>
pstruct = new
ArrayList<STRUCT>();
for(User
u : userList){
Object[]
objs = new
Object[4];
objs[0]
= u.getId();
objs[1]
= u.getUsername();
objs[2]
= u.getAge();
objs[3]
= u.getPassword();
STRUCT
struct = new
STRUCT(recDesc, conn, objs);
pstruct.add(struct);
}
ArrayDescriptor
tabDesc =
ArrayDescriptor.createDescriptor("OBJ_ARRAY",
conn);
ARRAY
vArray = new
ARRAY(tabDesc, conn, pstruct.toArray());
cstmt
= conn.prepareCall("call
saveObjArray(?,?,?)");
cstmt.setArray(1,
vArray);
cstmt.registerOutParameter(2,
Types.INTEGER);
cstmt.registerOutParameter(3,
Types.VARCHAR);
cstmt.execute();
System.out.println(cstmt.getString(2));
System.out.println(cstmt.getString(3));
cstmt.close();
conn.close();
}catch(Exception
e){
e.printStackTrace();
}
个变量,然后通过JDBC的方式得到Connection,然后定义要传给存储过程的数组。
映射
Oracle端对象
AS OBJECT类型
首先通过StructDescriptor.createDescriptor("USEROBJ",conn)定义对象描述方式。
然后,把java
bean 的各个属性赋值给Object类型的数组,通过new
STRUCT(recDesc, conn, objs)方法,把java
bean按照对象描述方式描述成Oracle可以识别的对象。最后放到数组里。
映射
Oracle端数组
AS TABLE OF类型
通过ArrayDescriptor.createDescriptor("OBJ_ARRAY",conn)定义数组描述方式。
在通过new
ARRAY(tabDesc, conn,
pstruct.toArray()),把要传入的数组按批定的数组描述方式生成一个新的Oracle定义的数组。
调用存储过程,传入参数并执行。
数组做为参数传入Oracle存储过程操作数据库的更多相关文章
- 将C# dataTable 做为参数传入到存储过程
1.list转换为DataTable(如果有需要) public static DataTable ListToDataTable<T>(List<T> entitys) { ...
- 写一个函数,将一个int型的数组做为参数传入,使用指针返回两个结果:最大值和最小值
今日下午研究了一下c语言中的指针问题,c语言的核心是指针,指针的核心是地址,地址的核心是内存. #include <stdio.h> void hanshu(int *arry,int s ...
- java如何将一个List传入Oracle存储过程
注:本文来源于 深圳gg < java如何将一个List传入Oracle存储过程 > 一:数据库端建一个PL/SQL的数组. CREATE OR REPLACE TYPE tabl ...
- java怎样将一个List传入Oracle存储过程
java怎样将一个List传入Oracle存储过程.样例例如以下: 数据库端建一个PL/SQL的数组. CREATE OR REPLACE TYPE tables_array AS VARRAY(10 ...
- C语言 数组做函数参数不传数组个数的遍历方法
//数组做函数参数不传数组个数的遍历方法 #include<stdio.h> #include<stdlib.h> #include<string.h> void ...
- C语言 数组做函数参数退化为指针的技术推演
//数组做函数参数退化为指针的技术推演 #include<stdio.h> #include<stdlib.h> #include<string.h> //一维数组 ...
- 【面试题003】c数组做为参数退化的问题,二维数组中的查找
[面试题003]c数组做为参数退化的问题,二维数组中的查找 一,c数组做为参数退化的问题 1.c/c++没有记录数组的大小,因此用指针访问数组中的元素的时候,我们要确保没有超过数组的边界, 通过下面 ...
- java怎样将一组对象传入Oracle存储过程
注:本文来源 < java怎样将一组对象传入Oracle存储过程 > java怎样将一组对象传入Oracle存储过程 java怎样将一组对象传入Oracle存储过程.须要注意的是jar ...
- go语言基础之数组做函数参数是值拷贝
1.数组做函数参数是值拷贝 示例: package main //必须有个main包 import "fmt" //数组做函数参数,它是值传递 //实参数组的每个元素给形参数组拷贝 ...
随机推荐
- SR4000笔记
长时间运行情况下需要有降温处理(40度以下) 建议使用触发模式而非连续模式 850nm波长的光(虽然无害,建议不要直视) 12V DC 滤波镜头(允许24个LED激光波长的通过) 快闪:获取数据 慢闪 ...
- [codevs3862]竞赛班的垃圾处理
题目描述 Description 竞赛班的师弟们都很懒,每个人都不喜欢倒垃圾,结果垃圾就会跟师兄的RP一样越堆越多,当然,老师时不时就会叫他们去倒垃圾.由于他们真的很懒,他们只会直接将垃圾桶最上面袋拿 ...
- Timer和counter
什么是Timer,什么是Counter 几乎每个嵌入式板都会有counter和timer,重要性比肩gpio.本质上来看timer和counter几乎是一样的东西,底层都是一个硬件counter,如果 ...
- ios iphone 将log在终端输出
对于模拟器,其在终端的log文件位于: -/Library/Logs/CoreSimulator/C4B94BA6-EF08-4AD2-AE7D-1A3A2E2AC545/system.log 对 ...
- 通过一张简单的图,让你彻底地搞懂JS的==运算
大家知道,JavaScript中的==是一种比较复杂运算,它的运算规则很奇怪,很容易让人犯错,从而成为JavaScript中“最糟糕的特性”之一. 在仔细阅读ECMAScript规范的基础上,我画了一 ...
- 来自奢侈品行业的CEO能给苹果带来什么?
重回苹果的奢侈品大佬:保罗丹诺威 作为伊夫·圣罗兰(Saint Laurent)时尚集团的前CEO,保罗丹诺威(Paul Deneve)9月将正式加入苹果公司,并负责该公司所谓的“特殊项目”,同时直接 ...
- ubuntu压缩解压
ubuntu安装解压rar 一般通过默认安装的ubuntu是不能解压rar文件的,只有在安装了rar解压工具之后,才可以解压.其实在ubuntu下安装rar解压工具是非常简单的,只需要两个步骤就可 ...
- SVProgressHUD 用法
SVProgressHUD 是一个第三方的控件,是一个弹出提示层,用来提示 网络加载 或 提示对错,看下面图,你就明白了: 那么,SVProgressHUD 都有什么特点呢: 1. 提示当 ...
- 【系列】Matei Zaharia(Spark系统作者)博士论文-0 摘要
随着处理器提升速度下降和数据量的不断增长,非常多公司和组织(既有互联网公司也有传统的企业另一些研究机构)都要求他们的应用可以Scale out到更大的分布式系统上(比方整个数据中心). 这些应用又分为 ...
- 让Windows Server 2008 + IIS 7+ ASP.NET 支持10万并发请求(转)
转自:http://www.cnblogs.com/dudu/archive/2009/11/10/1600062.html 今天下午17点左右,博客园博客站点出现这样的错误信息: Error Sum ...