ibatis中mysql存储过程返回结果集

 mysql存储过程可以直接返回结果集,同时可以有out参数
例如:

存储过程:

CREATE PROCEDURE `test`
(IN _login VARCHAR(32),
IN _psw VARCHAR(32),
OUT _ret INTEGER(10),
OUT _id INTEGER(10),
OUT _name VARCHAR(32),
OUT _email VARCHAR(32),
OUT _phone VARCHAR(20),
OUT _active INTEGER(11))     //同时返回多个结果集合

BEGIN
    DECLARE CONTINUE HANDLER FOR NOT FOUND set _ret =-1;
    set _ret = 0 ;

    select id,name,email,phone,active
    into _id,_name,_email,_phone,_active
    from test
    where tx_account.`loginname`=_login and tx_account.`password`=MD5(_psw) and active=1;
    ---------返回结果集-----
    if _ret = 0 then
       select a.id as id ,a.name as name,a.priority as priority
       from test b left join test1 a on b.role=a.id
       where b.account=_id;
    end if;
END;


直接返回结果集
ibatis文件(mapper文件)
<parameterMap id="testParameterMap" class="params">
    <parameter property="loginname" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>
    <parameter property="password" jdbcType="VARCHAR" javaType="java.lang.String" mode="IN"/>
    <parameter property="ret" jdbcType="INTEGER" javaType="java.lang.Integer" mode="OUT"/>
    <parameter property="id" jdbcType="INTEGER" javaType="java.lang.Integer" mode="OUT"/>    
    <parameter property="name" jdbcType="VARCHAR" javaType="java.lang.String" mode="OUT"/>
    <parameter property="phone" jdbcType="VARCHAR" javaType="java.lang.String" mode="OUT"/>
    <parameter property="email" jdbcType="VARCHAR" javaType="java.lang.String" mode="OUT"/>
    <parameter property="active" jdbcType="INTEGER" javaType="java.lang.Integer" mode="OUT"/>
</parameterMap>

<procedure id="test" parameterMap="testMap" resultMap="AccountRoleResultMap">
    {call test(?,?,?,?,?,?,?,?)}
</procedure>
   
dao 的实现
定义一个传参的map params ,

   HashMap<String,Object> params = new HashMap<String,Object>();
   //把需要的参数放到map中
   params.put("id",account.getId());
   params.put("ret",null);
   params.put("loginname", null);
   params.put("name", null);
   params.put("email", null);
   params.put("phone",null);
   params.put("active", null);
//定义一个list
   List list=null;
    list= (List)(getSqlMapClientTemplate().queryForList("test",params));
   //上面这样操作就可以获得存储过程返回的结果集。
    Object var;
    var = params.get("ret"); //从map 中获得制定的输出参数的值。


在mysql中不需要的ibatis的配置文件中,声明返回的结果集。

还没试过,不知道行不行,先放在这里。


转自:http://blog.csdn.net/yangzl0123/article/details/4743721


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值