oracle调用存储过程传递list参数

(一)jdbc连接:

--第一步,创建数据库对象  
CREATE OR REPLACE TYPE param_object is object(  
  configId nvarchar2(64),  
  evaluateScore number(18,2),  
  evaluateLevel nvarchar2(64)  
);   
  
  
--第二步,创建数据库list并且与数据库对象挂关系  
create type param_array as table of param_object;  
  
  
--第三步,创建存储过程将list<object>  
create or replace procedure PRO_UPDATE_EVALUATE_SCORE(paramList in param_array,  
                                                      result_id out varchar2) is  
begin  
  for i in 1 .. paramList.count loop  
    update SCM_TEST  
       set CONFIGID      = paramList(i).configId,  
           EVALUATESCORE = paramList(i).evaluateScore where  
           EVALUATELEVEL = paramList(i).evaluateLevel;  
           result_id := i;  
  end loop;  
  commit;  
end PRO_UPDATE_EVALUATE_SCORE;  




[java] view plain copy
package com.atguigu.springdata.test;  
  
import java.sql.Connection;  
import java.sql.DriverManager;  
import java.sql.SQLException;  
import java.sql.Types;  
import java.util.ArrayList;  
import java.util.Date;  
import com.sun.org.apache.xerces.internal.impl.dtd.models.DFAContentModel;  
  
import oracle.jdbc.OracleCallableStatement;  
import oracle.sql.ARRAY;  
import oracle.sql.ArrayDescriptor;  
import oracle.sql.STRUCT;  
import oracle.sql.StructDescriptor;  
  
public class Tesst {  
    // 数据库连接  
    private static final String connectionURL = "jdbc:oracle:thin:@127.0.0.1:1521/oracle11g";  
    private static final String userID = "oracle11g";  
    private static final String userPassword = "oracle11g";  
    private static final String driver_class = "oracle.jdbc.driver.OracleDriver";  
  
    public void runTest() {  
        //组装需要的参数List<String[]> String[] length 要和数据库的自定对象PARAM_OBJECT个数一样  
        String chars = "abcdefghijklmnopqrstuvwxyz";  
        ArrayList list = new ArrayList<>();  
        for(int i=0;i<2000;i++){  
            String c = chars.charAt((int)(Math.random() * 26))+"";  
            String[] values = { i + 1 + "", i + 1 + "",c.toUpperCase()};  
            list.add(values);  
        }  
             
             
        Connection con = null;  
        OracleCallableStatement stmt = null;  
        try {  
            Class.forName(driver_class).newInstance();  
            con = DriverManager.getConnection(connectionURL, userID,  
                    userPassword);  
              
            ARRAY aArray = getArray(con, "PARAM_OBJECT","PARAM_ARRAY", list,11);  
              
            System.out.println("开始时间:"+  new Date());  
            stmt = (OracleCallableStatement) con.prepareCall("{call PRO_UPDATE_EVALUATE_SCORE(?,?)}");  
              
            stmt.setARRAY(1, aArray);  
//          stmt.setArray(1, aArray);  
            stmt.registerOutParameter(2, Types.VARCHAR);  
              
            stmt.execute();  
            String string = stmt.getString(2);  
            System.out.println("结束时间:"+  new Date());  
            System.out.println("输出参数:"+string);  
        } catch (SQLException e) {  
            e.printStackTrace();  
        } catch (Exception e) {  
            e.printStackTrace();  
        } finally {  
            if (stmt != null) {  
                try {  
                    stmt.close();  
                } catch (SQLException e) {  
                    e.printStackTrace();  
                }  
            }  
            if (con != null) {  
                try {  
                    con.close();  
                } catch (SQLException e) {  
                    e.printStackTrace();  
                }  
            }  
        }  
    }  
  
    /** 
     * 将java数组转换成数据库数组 
     * @param con           原生jdbc链接,链接池的链接不行 
     * @param OracleObj     数据库自定义对象 
     * @param Oraclelist    数据库自定义数组 
     * @param objlist       需要的参数 
     * @param paramNum      自定义对象的个数 
     * @return   
     * @throws Exception 
     */  
    private ARRAY getArray(Connection con, String OracleObj,  
  
    String Oraclelist, ArrayList objlist,int paramNum) throws Exception {  
  
        ARRAY list = null;  
  
  
        if (objlist != null && objlist.size() > 0) {  
  
            StructDescriptor structdesc = StructDescriptor.createDescriptor(OracleObj,con);  
              
            STRUCT[] structs = new STRUCT[objlist.size()];  
  
            Object[] result = new Object[0];  
  
            for (int i = 0; i < objlist.size(); i++) {  
                Object[] object = (Object[]) objlist.get(i);  
                String[] str = (String[]) objlist.get(i);  
                  
                result = new Object[paramNum];  
  
                // 数组大小应和你定义的数据库对象(AOBJECT)的属性的个数  
                for(int j=0;j<paramNum;j++){  
                    result[j] = str[j];  
                }  
  
                // 将list中元素的数据传入result数组 result[1] = new Integer(..); //  
                structs[i] = new STRUCT(structdesc, con, result);  
            }  
  
            ArrayDescriptor desc = ArrayDescriptor.createDescriptor(Oraclelist,  
                    con);  
  
            list = new ARRAY(desc, con, structs);  
        }  
  
  
        return list;  
  
    }  
  
    public static void main(String[] args) {  
        Tesst testListToProcedure = new Tesst();  
        testListToProcedure.runTest();  
    }  
  
}  


注:自定义对象里面的字符必须要使用nvarchar2,不然java代码将字符串的格式封装不进去。链接要使用jdbc原生链接(Connection)才能对自定义对象和数组的转换,使用链接池转换不过来。如果谁使用了连接池成功了麻烦您评论下如何操作的,谢谢!



(2)oracle  mybatils调用

1.Controller层:

// 读取解析Excel,并判断是否解析成功
List<String[]> list = ReadExcel.batchimport(file);
List list1 = new ArrayList<Budgetinfo>();
int size = list.size();
if(size>1){
for(int i=1;i<size;i++){
String [] obj = list.get(i);
Budgetinfo budgetinfo=new Budgetinfo();
budgetinfo.setCreaty(obj[0]); // 年份
if(!StringUtil.isEmpty(obj[1])){
budgetinfo.setCreatm(Integer.parseInt(obj[1])); // 月份
}
budgetinfo.setOneOrgname(obj[2]); // 所属组织
budgetinfo.setOneSubjectname(obj[3]); // 一级科目
budgetinfo.setTwoSubjectname(obj[4]); // 二级科目
budgetinfo.setThreeSubjectname(obj[5]); // 三级科目
budgetinfo.setFourSubjectname(obj[6]); // 四级科目
if(!"0.0".equals(obj[7])){
budgetinfo.setBudget(Double.parseDouble(obj[7])); // 预算金额
}
budgetinfo.setCreatetor(user.getStaffname()); // 创建人

list1.add(budgetinfo);
budgetinfo = null;
}
//调用存储过程
HashMap<String,Object> map = new HashMap<String,Object>();
map.put("arr",list1);

res = service.importData(map);

2.dao层:

public BaseArgument importData(HashMap<String, Object> map) {
BaseArgument res=new BaseArgument();
getSqlSession().selectOne("BudgetinfoMapper.importExcelData", map);
return res;

}

3.XML代码:

<parameterMap type="java.util.Map" id="inputMap">  
        <parameter property="arr" jdbcType="ARRAY"  
            javaType="java.util.List" mode="IN" typeHandler="com.ydtx.comm.ListHandler"/>  
        <parameter property="v_out" jdbcType="VARCHAR"  
            javaType="java.lang.String" mode="OUT" />  

  </parameterMap> 

<!-- 调用存储过程导入excel数据 -->
<select id="importExcelData" statementType="CALLABLE" parameterMap="inputMap">
{call sp_loaddata(?,?)} 

</select>

3.对传入的List集合做处理的类

package com.ydtx.comm;


import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;


import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;


import com.ydtx.bean.pojo.payBudget.Budgetinfo;
import com.ydtx.utils.StringUtil;


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


public class ListHandler extends BaseTypeHandler{
  
    @SuppressWarnings("unchecked")  
    @Override  
    public void setNonNullParameter(java.sql.PreparedStatement parameterSetter, int i,  
            Object o, JdbcType jdbcType) throws SQLException {  
        Connection conn = null;  
        try {  
            if(null != o){  
                List<Budgetinfo> list = (ArrayList<Budgetinfo>) o;  
                conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.0.16:1521:oracle", "CWSYS", "CWSYS");  
                //这里必须得用大写,而且必须要引入一个包,如果不引入这个包的话字符串无法正常转换,包是:orai18n.jar  

                ARRAY array = getArray(conn, "USEROBJ", "OBJ_ARRAY", list);  //USEROBJ表示数据库自定义对象, OBJ_ARRAY表示数据库自定义数组
                parameterSetter.setArray(i, array);  
            }  
        } catch (Exception e) {  
            e.printStackTrace();  
        } finally{  
            if(null != conn){  
                conn.close();  
            }  
        }  
          
    }  
      
    @SuppressWarnings("rawtypes")  
    private ARRAY  getArray(Connection con,String OracleObj, String Oraclelist, List<Budgetinfo> listData) throws Exception {  
        ARRAY array = null;  
        ArrayDescriptor desc = ArrayDescriptor.createDescriptor(Oraclelist, con);  
        STRUCT[] structs = new STRUCT[listData.size()];  
        if (listData != null && listData.size() > 0){  
            StructDescriptor structdesc = new StructDescriptor(OracleObj, con);  
            for (int i = 0; i < listData.size(); i++){  
                Object[] result = {
                listData.get(i).getCreaty(), // 年份
                listData.get(i).getCreatm(), // 月份
                listData.get(i).getOneOrgname(), // 所属组织
                listData.get(i).getOneSubjectname(), // 一级科目
                listData.get(i).getTwoSubjectname(), // 二级科目
                listData.get(i).getThreeSubjectname(), // 三级科目
                listData.get(i).getFourSubjectname(), // 四级科目
                listData.get(i).getBudget(), // 预算金额
                listData.get(i).getCreatetor()
                };  
                structs[i] = new STRUCT(structdesc, con, result);  
            }  
            array = new ARRAY(desc, con, structs);  
        }else{  
            array = new ARRAY(desc, con, structs);  
        }  
        return array;  
    }


@Override
public Object getNullableResult(ResultSet rs, String columnName) throws SQLException {
// TODO Auto-generated method stub
return null;
}


@Override
public Object getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
// TODO Auto-generated method stub
return null;
}


@Override
public Object getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
// TODO Auto-generated method stub
return null;
}

}


  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值