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

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约束的常用操作及异常处理

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/305172.html<

(0)
运维的头像运维
上一篇2025-05-26 01:52
下一篇 2025-05-26 01:53

相关推荐

  • hosthatch瑞典,hosthatch瑞典服务器怎么样,hosthatch瑞典价格

    HostHatch 瑞典服务器在 2026 年依然是欧洲中小企业构建低延迟、高合规业务的首选方案,尤其适合需要严格遵循 GDPR 数据主权且追求极致性价比的跨境电商与 SaaS 团队,HostHatch 瑞典节点核心优势深度解析在 2026 年欧洲云基础设施格局中,瑞典节点凭借斯德哥尔摩(Stockholm)作……

    2026-05-02
    0
  • QuickClickHostingVPS测评,高防实测数据与性能表现,QuickClickHostingVPS怎么样?

    QuickClickHostingVPS 在 2026 年高防实测中展现出卓越的抗 DDoS 能力,其 10Gbps 清洗阈值与 99.99% 的 SLA 承诺使其成为高并发业务的首选,综合性价比优于多数同价位竞品,在云计算基础设施竞争白热化的 2026 年,选择 VPS 服务商不再仅看价格,更需关注其底层架构……

    2026-05-02
    0
  • HostSailor荷兰服务器怎么样?荷兰服务器租用推荐

    2026 年 HostSailor 荷兰服务器凭借超低延迟、合规的 GDPR 数据保护及极具竞争力的价格,是欧洲站群、跨境电商及 AI 算力部署的首选方案,在 2026 年的全球云计算版图中,荷兰阿姆斯特丹依然是连接欧亚非的绝对枢纽,HostSailor 作为深耕该区域的头部服务商,其核心优势在于不仅提供了物理……

    2026-05-02
    0
  • hosteonsVPS测评,实测体验好吗?hosteonsVPS怎么样

    Hosteons VPS 在 2026 年是否值得入手?结论是:对于追求极致性价比且业务主要面向东南亚或北美市场的中小开发者,其低价方案具备显著优势,但需警惕其高端线路的波动性,建议优先选择其位于新加坡或洛杉矶的入门级节点进行部署,在 2026 年云计算市场高度内卷的背景下,Hosteons 作为老牌 VPS……

    2026-05-02
    0
  • tragicservers是什么,tragicservers租用多少钱

    2026 年选择 tragicservers 的核心结论是:其凭借针对高并发游戏场景优化的独立节点架构与动态带宽调度技术,在低延迟稳定性与性价比之间取得了最佳平衡,尤其适合需要 24 小时不间断运行的竞技类项目,2026 年 tragicservers 性能深度解析与行业定位随着 2026 年云计算架构的进一步……

    2026-05-02
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注