java操作Oracle数据库——ARRAY、TABLE类型批量入库

本文介绍了使用Java操作Oracle数据库,通过ARRAY和TABLE类型实现批量入库的方法。首先展示了数据库表结构和PLSQL操作,然后详细说明了ARRAY类型的存储过程创建与Java调用,接着讲解了TABLE类型的批量入库操作,强调了在使用过程中需要导入orai18n.jar以避免字符串乱码问题。完整代码包括ArrayTestProc.java、DbUtil.java、TestBean.java和ordermanager.properties。
摘要由CSDN通过智能技术生成

        首先是我的数据库表(PLSQL操作)

--建表
create table TEST_TABLE  
(  
  yid      NUMBER,    
  ytel     VARCHAR2(50),   
  yanumber VARCHAR2(50)    
);

        这里记录两种方式:不管哪种方式、一定要记得导入orai18n.jar,否则一遇到字符串就乱码或添加不到数据库中。

一.ARRAY类型批量入库

        在数据库中建立相应的java对象(Oracle中的类型)和数组。

--类型
CREATE OR REPLACE TYPE yOracleObject AS OBJECT(  
       yid number,ytel varchar2(50),yanumber varchar2(50)  
);
--数组
CREATE OR REPLACE TYPE y_Oracle_LIST AS VARRAY(5000)  OF yOracleObject;

        创建完毕后在Types下面可以看到创建好的类型。

存储过程:

--存储过程
CREATE OR REPLACE PROCEDURE proc_test_new(y_Array IN y_oracle_list,  
                                          p_out   OUT NUMBER) AS  
  v_yID     number;  
  v_yTel    varchar(50);  
  v_anumber varchar(50);  
  v_type    yoracleobject;  
begin  
  FOR I IN 1 .. y_Array.COUNT LOOP  
    v_type    := y_Array(i);  
    v_yID     := v_type.yid;  
    v_yTel    := v_type.ytel;  
    v_anumber := v_type.yanumber;  
    insert into test_table values (v_yID, v_yTel, v_anumber);  
  end loop;  
  commit;  
  p_out := 0;  
EXCEPTION  
  WHEN OTHERS THEN  
    p_out := -1;  
    ROLLBACK;  
END; 

java代码:

ArrayTestProc.java

package com.bijian.study;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.ArrayList;

import oracle.jdbc.OracleCallableStatement;
import oracle.sql.ARRAY;
import oracle.sql.ArrayDescriptor;
import oracle.sql.STRUCT;
import oracle.sql.StructDescriptor;

@SuppressWarnings("unchecked")  
public class ArrayTestProc {  
  
    public static void main(String[] args) {
    	
        ArrayList arrayL = new ArrayList();  
        TestBean t = new TestBean();  
        t.setYid(1);  
        t.setYtel("1236");  
        t.setYanumber("骚年");  
        arrayL.add(t);  
        TestBean t1 = new TestBean();  
        t1.setYid(2);  
        t1.setYtel("1236");  
        t1.setYanumber("骚年");  
        arrayL.add(t1);    
        TestBean t2 = new TestBean();    
        t2.setYid(3);  
        t2.setYtel("1236");  
        t2.setYanumber("骚年");  
        arrayL.add(t2);  
        TestBean t3 = new TestBean();  
        t3.setYid(4);  
        t3.setYtel("1236");  
        t3.setYanumber("骚年");  
        arrayL.add(t3);  
        TestBean t4 = new TestBean();  
        t4.setYid(5);  
        t4.setYtel("1236");  
        t4.setYanumber("骚年");  
        arrayL.add(t4);  
        try {  
            /* 
             * 记得判断一下list集合的大小、如果集合大于你在数据设置的数组大小了、那么就要分批次提交 
             * 我的是y_Oracle_LIST AS VARRAY(5000)  
             * 那么当list集合的值等于5000的时候就入库了、 
             * 然后剩下的数据又从新用一个list来装、在继续判断...... 
             * 这里只是简单的演示、就不具体操作判断了 
             */  
            int backVal = newTest(arrayL);  
            System.out.println(backVal==0?"成功!":"失败!");  
        } catch (SQLException e) {  
            e.printStackTrace();  
        }  
    }  
    /** 
     * 将java中的arrayList转化 
     * @param con 数据库连接对象 
     * @param Oraclelist 数据数组类型名称 
     * @param objlist 要存储的list对象 
     * @return oracle.sql.ARRAY 
     * @throws Exception 
     */  
    private static ARRAY getOracleArray(Connection con, String Oraclelist,  
            ArrayList objlist) throws Exception {  
        ARRAY list = null;  
        if (objlist != null && objlist.size() > 0) {  
            /** 
             * 必须大写类型名称 
             * 否则会报错:java.sql.SQLException: 无效的名称模式: M_ORDER.yoracleobject 
             */  
            StructDescriptor structdesc = new StructDescriptor(  
                    "YORACLEOBJECT", con);  
            STRUCT[] structs = new STRUCT[objlist.size()];  
            Object[] result = new Object[0];  
            for (int i = 0; i < objlist.size(); i++) {  
                result = new Object[3];   
                TestBean t = (TestBean)(objlist.get(i));  
                result[0] = t.getYid();  
                result[1] = t.getYtel();    
                result[2] = t.getYanumber();   
                /* 
                 * 一定要记得导入orai18n.jar 
                 * 否则一遇到字符串就乱码、添加不到数据 
                 */  
                structs[i] = new STRUCT(structdesc, con, result);  
            }  
            ArrayDescriptor desc = ArrayDescriptor.createDescriptor(Oraclelist,  
                    con);  
            list = new ARRAY(desc, con, structs);  
        } else {  
            ArrayDescriptor desc = ArrayDescriptor.createDescriptor(Oraclelist,  
                    con);  
            STRUCT[] structs = new STRUCT[0];  
            list = new ARRAY(desc, con, structs);  
        }  
        return list;  
    }   
      
    /** 
     * 入库 
     * @param peoleList 要存储的list对象 
     * @return 
     * @throws SQLException 
     */  
    public static int newTest(ArrayList peoleList) throws SQLException{  
        Connection con = null;  
        CallableStatement stmt = null;  
        int backVal = -1;   
        try {  
            DbUtil d = new DbUtil();  
            con = d.getCon();  
            if (con != null) {  
                stmt = con.prepareCall("{call proc_test_new(?,?)}");  
                ARRAY adArray = getOracleArray(con, "Y_ORACLE_LIST",peoleList);  
                ((OracleCallableStatement) stmt).setARRAY(1, adArray);  
                stmt.registerOutParameter(2, java.sql.Types.INTEGER);  
                stmt.execute();   
                backVal = stmt.getInt(2);  
            }  
        } catch (Exception e) {  
            e.printStackTrace();   
        } finally {  
            if(stmt!=null){  
                stmt.close();  
            }  
            if(con!=null){  
                con.close();  
            }  
        }  
        return backVal;  
    }  
}

DbUtil.java

package com.bijian.study;

import java.io.IOException;  
import java.io.InputStream;  
import java.sql.Connection;  
import java.sql.DriverManager;  
import java.util.Properties;  
  
public class DbUtil {
	
    static Properties properties = null;  
  
    public DbUtil() {  
        // 读取.properties文件的信息  
        properties = new Properties();  
        InputStream in = getClass().getResourceAsStream("ordermanager.properties");  
        try {  
            properties.load(in);    
        } catch (IOException ex) {  
            System.out.println(ex.getMessage());  
            ex.printStackTrace();  
        }  
    }  
      
    /** 
     * <LI>获取连接对象</LI> 
     *  
     * @return 
     */  
     public Connection getCon() {  
            Connection connection = null;    
            try {  
                String url=properties.getProperty("jdbc.url");  
                String user=properties.getProperty("jdbc.username");  
                String pwd=properties.getProperty("jdbc.password");  
                String driver=properties.getProperty("jdbc.driverClassName");  
                Class.forName(driver);                   
                connection = DriverManager.getConnection(url, user, pwd);  
            } catch (Exception err) {  
                  System.out.println("错误:ConDB-->getCon()____JDBC连接失败!");  
                err.printStackTrace();  
                return null;  
            }  
            return connection;  
    }    
}

TestBean.java

package com.bijian.study;

public class TestBean {

	private int yid;
	private String ytel;
	private String yanumber;
	
	public int getYid() {
		return yid;
	}
	public void setYid(int yid) {
		this.yid = yid;
	}
	public String getYtel() {
		return ytel;
	}
	public void setYtel(String ytel) {
		this.ytel = ytel;
	}
	public String getYanumber() {
		return yanumber;
	}
	public void setYanumber(String yanumber) {
		this.yanumber = yanumber;
	}
}

ordermanager.properties

jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@10.20.128.18:1521:orcl
jdbc.username=test
jdbc.password=root

运行结果:


 

二.TABLE类型批量入库

        不用判断list集合大小、不用考虑数组长度的做法就是用table。

使用的类型:你要新增的数据有多少字段就添加相应个数的类型

--类型
create or replace type i_table is table of number;  
create or replace type t_table is table of varchar2(30);  
create or replace type a_table is table of varchar2(30);

存储过程:

--存储过程
create or replace procedure pro_forall_insert(v_1 i_table,  
                                              v_2 t_table,  
                                              v_3 a_table) as  
begin  
  forall i in 1 .. v_1.count 
     insert into test_table values (v_1(i), v_2(i), v_3(i)); 
END; 

java代码:

package com.bijian.study;

import java.sql.CallableStatement;
import java.sql.Connection;

import oracle.sql.ARRAY;

@SuppressWarnings("unchecked")  
public class TableTestProc {  
  
    public static void main(String[] args) {  
        Connection con = null;  
        CallableStatement cstmt = null;  
        oracle.sql.ArrayDescriptor a = null;  
        oracle.sql.ArrayDescriptor b = null;  
        oracle.sql.ArrayDescriptor c = null;  
        DbUtil d = new DbUtil();  
        con = d.getCon();  
          
        Object[] s1 = new Object[10000];  
        Object[] s2 = new Object[10000];  
        Object[] s3 = new Object[10000];  
  
        for (int i = 0; i < 10000; i++) {  
            s1[i] = new Integer(i);  
            s2[i] = "ttt"+i;  
            s3[i] = "aaa"+i;  
        }
        try {  
            a = oracle.sql.ArrayDescriptor.createDescriptor("I_TABLE", con);  
            b = oracle.sql.ArrayDescriptor.createDescriptor("T_TABLE", con);  
            c = oracle.sql.ArrayDescriptor.createDescriptor("A_TABLE", con);  
            ARRAY a_test = new ARRAY(a, con, s1);  
            ARRAY b_test = new ARRAY(b, con, s2);  
            ARRAY c_test = new ARRAY(c, con, s3);  
            cstmt = con.prepareCall("{ call pro_forall_insert(?,?,?) }");  
            cstmt.setObject(1, a_test);  
            cstmt.setObject(2, b_test);  
            cstmt.setObject(3, c_test);    
            cstmt.execute();  
            con.commit();  
        } catch (Exception e) {
            e.printStackTrace();  
        }  
    }  
}

运行结果:


        最后:Java在操作数据库存储过程时如果需要用到array或者table数据类型的话,需要导入orai18n.jar包,否则一遇到字符串就乱码、添加不到数据!

 

文章来源:http://blog.csdn.net/hzw2312/article/details/8444462

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值