ibatis3.X如何调用Oracle存储过程定义的in数组

harryzyp 2011-01-25 08:38:24
oracle定义数组:
CREATE OR REPLACE TYPE voucher_distribute_list as table of voucher_distribute;

CREATE OR REPLACE TYPE voucher_distribute AS OBJECT
(
name VARCHAR2(100),
code VARCHAR2(10)
);

ibatis3 如何调用存储过程定义了in输入参数的voucher_distribute_list
非常感谢
...全文
917 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复

package org.yhb.ibatis.model;

import java.io.Serializable;
import java.util.Date;

public class User implements Serializable{
private static final long serialVersionUID = -6919964218508186044L;
private int id;
private String name;
private Date birthday;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
}


<!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD iBatis Mapper 3.0 //EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
<mapper namespace="org.yhb.ibatis.dao.UserDAO">
<!-- 表结构
create table IBATIS_USER
(
ID NUMBER not null,
NAME VARCHAR2(20) not null,
BRITHDAY DATE not null
)
-->

<!-- 存储过程
create or replace procedure getAllUser(userList out sys_refcursor)
as
begin
open userList for select * from ibatis_user;
end;
-->

<!-- resultMap -->
<resultMap type="User" id="userMap">
<id column="id" property="id" />
<result column="name" property="name" />
<result column="birthday" property="birthday" />
</resultMap>

<!-- 调用存储过程 -->
<select id="getAllUser" statementType="CALLABLE">
{call
getAllUser(#{userList,<!-- 参数 -->
mode=OUT,<!-- 参数类型 -->
javajavaType=java.sql.ResultSet,<!-- 参数java类型 -->
jdbcType=CURSOR,<!-- 参数jdbc类型 -->
resultMap=userMap<!-- ResultSet需要resultMap参数 -->
})}
</select>
</mapper>


@Test
public void testProcedure() throws Exception {
Reader reader = null;
reader = Resources.getResourceAsReader("configuration.xml");
SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(reader);
reader.close();

SqlSession session = ssf.openSession();
Map map = new HashMap();
session.selectOne("org.yhb.ibatis.dao.UserDAO.getAllUser", map);
System.out.println(map);
//返回的集合被放入了map中
List<User> userList = (List<User>) map.get("userList");
System.out.println(userList);
session.close();
}





希望对你有帮助
harryzyp 2011-01-26
  • 打赏
  • 举报
回复
不是简单调用存储过程,是这个存储过程有个in参数的数组
xieshengjun2009 2011-01-26
  • 打赏
  • 举报
回复
持久层实现类:
public String dealPay(HashMap map) {
this.getSqlMapClientTemplate().queryForObject("CM_BILL.dealpay", map);
return map.get("rslt_str").toString();
}

sqlMap.xml文件:
<parameterMap class="java.util.Map" id="p-dealpay">

<parameter javaType="java.lang.String" jdbcType="VARCHAR" mode="OUT" property="rslt_str" />
<parameter javaType="java.lang.String" jdbcType="VARCHAR" mode="IN" property="begin_date_i" />
<parameter javaType="java.lang.String" jdbcType="VARCHAR" mode="IN" property="end_date_i" />
<parameter javaType="java.lang.String" jdbcType="VARCHAR" mode="IN" property="branch_i" />
<parameter javaType="java.lang.String" jdbcType="VARCHAR" mode="IN" property="customer_type_i" />
</parameterMap>

<procedure id="dealpay" parameterMap="p-dealpay">
{call F_rep_get_billmonth(?,?,?,?)}
</procedure>


这些已经足够可以让你知道怎么调用存储过程了。其他的你在发挥发挥!
harryzyp 2011-01-26
  • 打赏
  • 举报
回复
你这个是out参数的,还不符合要求,但也非常感谢了
内容概要:本文研究油浸式变压器在不同气候条件下的能量极限问题,通过Matlab代码实现建模与仿真,深入分析环境温度、湿度等气候因素对变压器热稳定性、负载能力及运行安全性的影响,进而确定其在多种工况下的最大能量承载极限。研究采用多智能体方法提升模型的适应性与仿真精度,综合考虑热平衡方程与环境参数输入,旨在为变压器的设计优化、容量规划、动态负载管理及智能电网中的可靠性分析提供科学依据和技术支撑。; 适合人群:具备电力系统基础知识和Matlab编程能力,从事电气工程、能源系统仿真、电力设备设计等相关领域的科研人员与工程师,特别适合研究生及工作1-5年的专业技术人才; 使用场景及目标:①评估油浸式变压器在极端气候环境下的安全运行边界;②优化变压器的负载调度与能效管理策略;③支持智能电网背景下设备级动态容量规划与韧性电网建设;④为高可靠性供电系统的设计与运维提供理论参考; 阅读建议:学习者应结合提供的Matlab代码深入理解建模流程,重点掌握热传导模型构建、环境变量设定、多智能体协同机制及仿真参数调优方法,并通过调整气候条件进行多场景仿真实验,以深化对变压器能量极限形成机理的认知。
内容概要:本文系统研究了基于开关电容器的级联多电平逆变器在布尔PWM控制技术下的工作特性与仿真实现,深入分析该拓扑结构的工作原理、电容电压自平衡能力及其对输出波形质量的优化作用。通过Simulink平台构建完整的系统仿真模型,验证布尔PWM控制策略在抑制谐波畸变、提升直流电压利用率和改善输出电压精度方面的有效性,进一步探讨其在高效率、高电能质量要求的电力电子变换系统中的应用潜力,为新型多电平逆变器的设计与控制提供理论依据与技术支撑。; 适合人群:电气工程、自动化、电力电子与电力传动等相关专业的高校本科生、研究生,从事新能源发电、电机驱动及电力系统仿真的科研人员,以及具备MATLAB/Simulink基础并希望深入理解先进PWM控制技术的工程技术人员。; 使用场景及目标:①掌握开关电容器型级联多电平逆变器的结构优势与运行机理;②理解布尔PWM控制的基本原理及其在多电平调制中的独特优势;③通过Simulink仿真实践,掌握控制模型搭建、参数整定与仿真结果分析方法;④为开展高性能逆变器相关课题研究或实际工程项目提供可复现的技术参考与设计思路。; 阅读建议:建议读者结合Simulink模型进行同步操作,重点关注布尔逻辑调制信号的生成方式、开关器件的驱动时序设计及电容电压动态响应特性,对比传统载波PWM等调制方法的性能差异,深入理解控制策略对系统稳态与动态性能的影响。同时可进一步拓展学习空间矢量PWM(SVPWM)、最近电平逼近(NLC)等其他先进调制技术,以全面掌握多电平逆变器的控制体系。

67,538

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧