自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle數(shù)據(jù)庫(kù)增刪集合元素的Java實(shí)現(xiàn)方法

數(shù)據(jù)庫(kù) Oracle
本文我們主要介紹了Oracle數(shù)據(jù)庫(kù)中增刪集合元素的一個(gè)Java源程序的示例,通過這個(gè)示例,我們可以實(shí)現(xiàn)Oracle數(shù)據(jù)庫(kù)增刪集合元素的操作,希望能夠?qū)δ兴鶐椭?/div>

Oracle數(shù)據(jù)庫(kù)增刪集合元素的操作該如何實(shí)現(xiàn)呢?其實(shí)利用Java Function就可以輕松的實(shí)現(xiàn),本文我們就主要介紹這一實(shí)現(xiàn)方法。

源程序如下:

  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. }  

然后發(fā)布: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'; 

 

測(cè)試:update test1 set cates = addElementOfInt_nt(cates, 10) where code=1;

關(guān)于Oracle數(shù)據(jù)庫(kù)中增刪集合元素的Java Function的實(shí)現(xiàn)方法就介紹到這里了,希望本次的介紹能夠?qū)δ兴鶐椭?/p>

【編輯推薦】

  1. Oracle數(shù)據(jù)庫(kù)AWR的使用實(shí)例詳解
  2. Oracle數(shù)據(jù)庫(kù)ASH和AWR的簡(jiǎn)單介紹
  3. Oracle數(shù)據(jù)庫(kù)通過在線重定義的方法新增字段詳解
  4. Oracle數(shù)據(jù)庫(kù)中AWR的組成及工作原理的詳細(xì)介紹
  5. Oracle數(shù)據(jù)庫(kù)Constraint約束的常用操作及異常處理

 

責(zé)任編輯:趙鵬 來(lái)源: 火魔網(wǎng)
相關(guān)推薦

2011-04-13 14:07:17

OracleSybase數(shù)據(jù)庫(kù)

2010-10-26 11:04:48

oracle數(shù)據(jù)導(dǎo)入

2010-05-06 09:30:16

Oracle創(chuàng)建數(shù)據(jù)庫(kù)

2010-10-28 14:18:01

oracle數(shù)據(jù)庫(kù)版本

2010-10-27 14:15:44

Oracle數(shù)據(jù)庫(kù)效率

2011-09-02 14:18:53

OracleBULK COLLECFORALL

2011-02-28 13:31:17

Oracle數(shù)據(jù)庫(kù)

2010-10-26 16:27:37

連接Oracle數(shù)據(jù)庫(kù)

2011-04-12 10:09:33

Oracle數(shù)據(jù)庫(kù)關(guān)閉

2010-10-26 16:07:45

連接oracle數(shù)據(jù)庫(kù)

2010-10-27 17:11:35

oracle查詢

2018-07-03 15:05:34

數(shù)據(jù)庫(kù)Oracle數(shù)據(jù)提取

2010-04-20 11:41:55

Oracle數(shù)據(jù)庫(kù)

2010-10-26 15:54:02

連接oracle數(shù)據(jù)庫(kù)

2011-04-08 09:07:25

Access數(shù)據(jù)庫(kù)Oracle庫(kù)

2010-11-15 10:02:49

Oracle數(shù)據(jù)庫(kù)重新

2010-11-19 14:42:37

Oracle數(shù)據(jù)庫(kù)啟動(dòng)

2011-04-12 15:44:08

Oracle數(shù)據(jù)庫(kù)

2010-04-22 16:08:24

Oracle數(shù)據(jù)庫(kù)

2012-02-03 10:32:46

Java
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)