java代码
public Connection conn() {
try {
// 第一步:加载JDBC驱动
Class.forName("oracle.jdbc.driver.OracleDriver");
// 第二步:创建数据库连接
con = DriverManager.getConnection("jdbc:oracle:thin:@192.177.2.2:1521/db", "test","test");
return con;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
public List getCanorderTemplateBySms(String version, String orderFrom,String acco, String accoType, String tunnelType, String callFrom) {
CallableStatement callStat=null;
ResultSet rs=null;
List list=new ArrayList();
String sql = "{call pkg_customerorder.sp_sms_canorder2(?,?,?,?,?,?,?,?,?)}";
try {
callStat = this.conn().prepareCall(sql);
callStat.setString(1,version);
//out
callStat.registerOutParameter(2,oracle.jdbc.OracleTypes.VARCHAR);
callStat.registerOutParameter(3,oracle.jdbc.OracleTypes.VARCHAR);
callStat.registerOutParameter(4,oracle.jdbc.OracleTypes.CURSOR);
//in
callStat.setString(5, orderFrom); //可订制渠道 1:客服 2:网站 3: 网站和客服
callStat.setString(6, acco);//账号
callStat.setString(7, accoType);//1代表客户编号 2代表基金账号
callStat.setString(8,tunnelType); //通道类别 0:不分通道 1:普通通道 2:专户通道
callStat.setString(9, callFrom);//调用恒生的接口需传入固定的参数9
callStat.execute();
String result= callStat.getString(2);//获得返回参数 返回代码'0000'表示成功
if(result!=null && "0000".equals(result.trim())){
rs=(ResultSet)callStat.getObject(4);
while(rs.next()){
TaskTemp taskTemp = new TaskTemp();
if("1".equals(rs.getString(3).trim())){ //基金客户是否可订制: 0-不可订制 1-可订制
taskTemp.setTaskcode(rs.getString(1));
taskTemp.setTaskname(rs.getString(2));
taskTemp.setBusinsubtype(rs.getString(15)); //分类编号 需要明天核对
taskTemp.setBusinsubname(rs.getString(16)); //分类名称 需要明天核对
list.add(taskTemp);
}
}
}
} catch (SQLException e) {
e.printStackTrace();
}
return list;
}
存储过程
/* * 如下接口为外围的封装接口(入参全部为字符串),主要供友商使用,内部不推荐使用 * 功能:查询客户当前可订制的短信模板 * 入参: sInVersion 版本信息 * sOrderFrom 可订制渠道 * sAcco 账号 * sAccotype 账号类型 1-客户编号 2-基金账号 3-交易账号(暂不使用) * nTunnelType 通道类型 0:不分通道;default 1:普通通道; 2:专户通道; * callFrom 调用来源(恒生系统调用接口不用传参数,佳锐等非恒生系统调用需传入值9) * 出参: sOutResultCode 返回代码 返回代码'0000'表示成功 * sOutResultInfo 返回信息 成功则返回'成功',否则返回具体失败原因 */ procedure sp_sms_canorder2( sInVersion in varchar2, --版本信息 sOutResultCode out varchar2, sOutResultInfo out varchar2, curOutResult out refcusor, sOrderFrom in varchar2, --可订制渠道 sAcco in varchar2, sAccotype in varchar2, nTunnelType in pls_integer := 0,--0:不分通道;default --1:普通通道; --2:专户通道; callFrom in varchar2 default '5' );