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 }

数组里存储的是Stringintlang等基本数据类型或引用数据类型(不包括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存储过程操作数据库的更多相关文章

  1. 将C# dataTable 做为参数传入到存储过程

    1.list转换为DataTable(如果有需要) public static DataTable ListToDataTable<T>(List<T> entitys) { ...

  2. 写一个函数,将一个int型的数组做为参数传入,使用指针返回两个结果:最大值和最小值

    今日下午研究了一下c语言中的指针问题,c语言的核心是指针,指针的核心是地址,地址的核心是内存. #include <stdio.h> void hanshu(int *arry,int s ...

  3. java如何将一个List传入Oracle存储过程

    注:本文来源于  深圳gg  < java如何将一个List传入Oracle存储过程   > 一:数据库端建一个PL/SQL的数组. CREATE OR REPLACE TYPE tabl ...

  4. java怎样将一个List传入Oracle存储过程

    java怎样将一个List传入Oracle存储过程.样例例如以下: 数据库端建一个PL/SQL的数组. CREATE OR REPLACE TYPE tables_array AS VARRAY(10 ...

  5. C语言 数组做函数参数不传数组个数的遍历方法

    //数组做函数参数不传数组个数的遍历方法 #include<stdio.h> #include<stdlib.h> #include<string.h> void ...

  6. C语言 数组做函数参数退化为指针的技术推演

    //数组做函数参数退化为指针的技术推演 #include<stdio.h> #include<stdlib.h> #include<string.h> //一维数组 ...

  7. 【面试题003】c数组做为参数退化的问题,二维数组中的查找

    [面试题003]c数组做为参数退化的问题,二维数组中的查找  一,c数组做为参数退化的问题 1.c/c++没有记录数组的大小,因此用指针访问数组中的元素的时候,我们要确保没有超过数组的边界, 通过下面 ...

  8. java怎样将一组对象传入Oracle存储过程

    注:本文来源 <  java怎样将一组对象传入Oracle存储过程  > java怎样将一组对象传入Oracle存储过程 java怎样将一组对象传入Oracle存储过程.须要注意的是jar ...

  9. go语言基础之数组做函数参数是值拷贝

    1.数组做函数参数是值拷贝 示例: package main //必须有个main包 import "fmt" //数组做函数参数,它是值传递 //实参数组的每个元素给形参数组拷贝 ...

随机推荐

  1. JS中Date.parse方法返回NaN解决方案

    Date.parse()方法: //将时间字符串转换为秒数 var date_str = '2013-12-3 18:32:00'; alert(date_str.replace(/-/g,'/')) ...

  2. JZ2440开发笔记(4)——设置静态IP

    1. 配置静态ip地址 $sudo vim /etc/network/interfaces 原有内容只有如下两行: auto lo iface lo inet loopback 向末尾追加以下内容: ...

  3. 四元数(Quaternion)详细讲解以及在图形图像编程中的使用

    关于四元数介绍可以直接看wiki,写的很详细了. 四元数的基本运算:http://www.linuxgraphics.cn/opengl/opengl_quaternion.html,代码有些问题. ...

  4. Web---JSP-EL表达式

    EL表达式简介 EL 全名为Expression Language. EL主要作用: 获取数据: EL表达式主要用于替换JSP页面中的脚本表达式,以从各种类型的java对象中获取数据. 执行运算: 利 ...

  5. Linux下简单的socket通信实例

    Linux下简单的socket通信实例 If you spend too much time thinking about a thing, you’ll never get it done. —Br ...

  6. 不同的jar里边相同的包名类名怎么区别导入

    今天在做项目的时候遇到了一个很有意思的问题,折磨了我很长时间,不过最终还是解决了,特留此文纪念一下. 遇到的问题: 同样一段代码,在同事那就好使,在我这就找不到一个方法.引用的包也都是相同的,这种问题 ...

  7. Hbase集群无法关闭

    执行stop-hbase.sh关闭Hbase服务器,提示一直在等待,查阅了很多网上的资料找到了答案.因为hbase的主要信息存储在zookeeper集群中,zookeeper集群没有正常启动会导致hb ...

  8. CF_402C Searching for Graph 乱搞题

    题目链接:http://codeforces.com/problemset/problem/402/C /**算法分析: 乱搞题,不明白题目想考什么 */ #include<bits/stdc+ ...

  9. rand(7) 到rand(10)

    说有一个rand()函数,等概率生成1-7的随机数. 利用这个函数,构造一个能生成1-10的随机数的函数; //意思大家都懂就好,没说清的就按照想象的走 我想只要输出的10个数概率相同就好,从宏观上看 ...

  10. poj 3984 迷宫问题【bfs+路径记录】

    迷宫问题 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10103   Accepted: 6005 Description ...