失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > jdbc oracle存储过程 java jdbc 执行oracle存储过程

jdbc oracle存储过程 java jdbc 执行oracle存储过程

时间:2023-03-12 15:13:37

相关推荐

jdbc oracle存储过程 java jdbc 执行oracle存储过程

java jdbc 执行oracle存储过程

发布时间:-07-12 08:25:32

来源:51CTO

阅读:188

作者:v512345

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'

);

如果觉得《jdbc oracle存储过程 java jdbc 执行oracle存储过程》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。