ibatis中 in的用法

本文摘自:http://stanlyy.iteye.com/blog/659686

ibatis中的sql语句处理in()的方法:

Xml代码   收藏代码
  1. <select id="totalCustomSum" parameterClass="customReport" resultClass="customReport">  
  2.         select sg.client_group_id as clientId, client_group_name as clientName,count(u.clientuser_id) as currentCount   
  3.         From sys_client_group sg left join clientinfo_group g on  sg.client_group_id = g.Client_group_id   
  4.         left join  user_info_msg u on u.clientuser_idg.clientuser_id  
  5.         <isNotEmpty property="startDate">  
  6.             <![CDATA[ and u.createtime >= #startDate#]]>  
  7.         </isNotEmpty>  
  8.         <isNotEmpty property="endDate">  
  9.             <![CDATA[ and u.createtime <= #endDate#]]>  
  10.         </isNotEmpty>  
  11.         <isNotEmpty property="userIdList">  
  12.             and u.user_id in  
  13.             <iterate  property="userIdList" conjunction="," close=")" open="(" >  
  14.                 #userIdList[]#  
  15.             </iterate>  
  16.         </isNotEmpty>  
  17.         group by sg.client_group_id   
  18.     </select>  

 

或者是:

Xml代码   收藏代码
  1. <select id="totalCustomSum" parameterClass="customReport" resultClass="customReport">  
  2.         select sg.client_group_id as clientId, client_group_name as clientName,count(u.clientuser_id) as currentCount   
  3.         From sys_client_group sg left join clientinfo_group g on  sg.client_group_id = g.Client_group_id   
  4.         left join  user_info_msg u on u.clientuser_idg.clientuser_id  
  5.         <isNotEmpty property="startDate">  
  6.             <![CDATA[ and u.createtime >= #startDate#]]>  
  7.         </isNotEmpty>  
  8.         <isNotEmpty property="endDate">  
  9.             <![CDATA[ and u.createtime <= #endDate#]]>  
  10.         </isNotEmpty>  
  11.         <isNotEmpty property="user_id">  
  12.             and u.user_id in($user_id$)  
  13.         </isNotEmpty>  
  14.         group by sg.client_group_id   
  15.     </select>  

 

其中第二种方法注意 in()里面取值的符号是“$”而不是通常用的“#”



在另一个博客上写着:可以试试。


  1. <select id="XXXX.list" parameterClass="java.util.ArrayList" resultClass="XXXXX">  
  2.         select * from XXXX  
  3.         <dynamic  prepend=" where XXXX in">  
  4.             <iterate open="("  close=")"  conjunction="," >  
  5.                 #[]#  
  6.             </iterate>  
  7.         </dynamic>   
  8.     </select>  

 

 

  传入一个List 用迭代器转换为 in (x,x,x,x,x,x,x……)


  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值