Oracle数据库增删集合元素的Java实现方法

数据库 Oracle
本文我们主要介绍了Oracle数据库中增删集合元素的一个Java源程序的示例,通过这个示例,我们可以实现Oracle数据库增删集合元素的操作,希望能够对您有所帮助。

Oracle数据库增删集合元素的操作该如何实现呢?其实利用Java Function就可以轻松的实现,本文我们就主要介绍这一实现方法。

源程序如下:

  1. package zgdx.action; import java.math.BigDecimal;  
  2. import java.sql.Array;  
  3. //import java.sql.Connection;  
  4. import java.sql.DriverManager;  
  5. import java.sql.SQLException;  
  6. import java.util.ArrayList;  
  7. import java.util.logging.Level;  
  8. import java.util.logging.Logger;  
  9. import oracle.jdbc.*;  
  10. import oracle.sql.ARRAY;  
  11. import oracle.sql.ArrayDescriptor; public class OraTools {  
  12.     static public Array addElementOfArray(ARRAY ary, Object e){  
  13.         try {  
  14.             Object[] bigs = null;  
  15.             if(ary==null)   bigs = new Object[0];  
  16.             else  bigs =  (Object[]) ary.getArray();  
  17.             for(int i=0; i<bigs.length; i++)  
  18.                 if(e.equals(bigs[i])){ return ary; }  
  19.             Object[] objs = new Object[bigs.length+1];  
  20.             for(int i=0; i<bigs.length; i++)  objs[i] = bigs[i];  
  21.             objs[objs.length-1] = e;  
  22.             OracleConnection conn = (OracleConnection) DriverManager.getConnection("jdbc:default:connection:");  
  23.             //((OracleConnection)conn.unwrap(OracleConnection.class))  
  24.             //Array arr = conn.createARRAY(typeName.toUpperCase(), objs );  //11g r1  
  25.             Array arr = new ARRAY(ArrayDescriptor.createDescriptor( ary.getSQLTypeName(), conn), conn, objs);  
  26.             return arr;  
  27.         } catch (SQLException ex) {  
  28.             //Logger.getLogger(OraTools.class.getName()).log(Level.SEVERE, null, ex);  
  29.             System.err.println("ERROR! addElementOfVarray: " + ex.getMessage());  
  30.             return ary;     }     static public Array delElementOfArray(ARRAY ary, Object e){  
  31.         try {  
  32.             if( ary==null)  return null;  
  33.             Object[] bigs =  (Object[]) ary.getArray();  
  34.             ArrayList list = new ArrayList(bigs.length);  
  35.             for(int i=0; i<bigs.length; i++)  
  36.                 if( ! e.equals(bigs[i])){ list.add(bigs[i]); }  
  37.             if(list.size()==bigs.length)  return ary;  
  38.             Object[] objs = list.toArray();  
  39.             OracleConnection conn = (OracleConnection) DriverManager.getConnection("jdbc:default:connection:");  
  40.             //Array arr = conn.createARRAY(typeName.toUpperCase(), objs );  //11g r1  
  41.             Array arr = new ARRAY(ArrayDescriptor.createDescriptor(ary.getSQLTypeName(), conn), conn, objs);  
  42.             return arr;  
  43.         } catch (SQLException ex) {  
  44.             System.err.println("ERROR! addElementOfVarray: " + ex.getMessage());  
  45.             return ary;     }  
  46. }  

然后发布:loadjava -f -v -user username/passwd -r OraTools.java

建call spec:

  1. CREATE OR REPLACE function addElementOfInt_nt(ary int_nt, dept_id NUMBER)   
  2.  
  3. return int_nt AS LANGUAGE JAVA NAME 'zgdx.action.OraTools.addElementOfArray(java.sql.Array, java.lang.Object) return java.sql.Array'; 

 

测试:update test1 set cates = addElementOfInt_nt(cates, 10) where code=1;

关于Oracle数据库中增删集合元素的Java Function的实现方法就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. Oracle数据库AWR的使用实例详解
  2. Oracle数据库ASH和AWR的简单介绍
  3. Oracle数据库通过在线重定义的方法新增字段详解
  4. Oracle数据库中AWR的组成及工作原理的详细介绍
  5. Oracle数据库Constraint约束的常用操作及异常处理

 

责任编辑:赵鹏 来源: 火魔网
相关推荐

2010-10-26 11:04:48

oracle数据导入

2010-10-28 14:18:01

oracle数据库版本

2010-05-06 09:30:16

Oracle创建数据库

2010-10-27 14:15:44

Oracle数据库效率

2011-04-13 14:07:17

OracleSybase数据库

2011-09-02 14:18:53

OracleBULK COLLECFORALL

2011-04-12 10:09:33

Oracle数据库关闭

2011-02-28 13:31:17

Oracle数据库

2010-10-26 16:07:45

连接oracle数据库

2010-10-26 16:27:37

连接Oracle数据库

2018-07-03 15:05:34

数据库Oracle数据提取

2010-10-27 17:11:35

oracle查询

2010-10-26 15:54:02

连接oracle数据库

2011-04-12 15:44:08

Oracle数据库

2010-11-19 14:42:37

Oracle数据库启动

2010-11-15 10:02:49

Oracle数据库重新

2010-04-20 11:41:55

Oracle数据库

2011-04-08 09:07:25

Access数据库Oracle库

2010-04-22 16:08:24

Oracle数据库

2009-03-30 14:52:43

复制数据库Oracle
点赞
收藏

51CTO技术栈公众号