Oracle数据库增删集合元素的Java实现方法_Oracle_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Oracle > Oracle数据库增删集合元素的Java实现方法

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

 2013/8/10 1:23:12    程序员俱乐部  我要评论(0)
  • 摘要:Oracle数据库中增删集合元素的操作该如何实现呢?其实利用JavaFunction就可以轻松的实现,本文我们就主要介绍这一实现方法。源程序如下:packagezgdx.action;importjava.math.BigDecimal;importjava.sql.Array;//importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.SQLException;importjava.util
  • 标签:方法 实现 ORA Java 数据库 数据 Oracle Oracle数据库

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

源程序如下:

    class="dp-xml">
  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的实现方法就介绍到这里了,希望本次的介绍能够对您有所帮助。

发表评论
用户名: 匿名