mybatis 循环遍历
/****Service/
public ServiceMessage<MemberFreedomRepModel> getMFListByPay(Long memberId,Long freedomType,Long paymentId,BigDecimal money) {
try { if(memberId==null || memberId==0){ return super.returnParamsError("memberId不能为空!"); } if(freedomType==null || freedomType==0){ return super.returnParamsError("freedomType不能为空!"); } if(paymentId==null || paymentId==0){ return super.returnParamsError("paymentId不能为空!"); } if(money.compareTo(BigDecimal.ZERO) <= 0){ return super.returnParamsError("充值金额不能为空!"); } if(!freedomType.equals(MemberRankType.chongzhijiangli.getType())){ return super.returnParamsError("此接口只提供给"+MemberRankType.chongzhijiangli.getTypeName()+"使用!"); } //先查询会员的角色 MemberRoleConnRepModel mm = new MemberRoleConnRepModel(); mm.setMemberId(memberId); ServiceMessage<List<MemberRoleConnRepModel>> msgRes = memberRoleConnRepModelService.queryByList(mm); if(!msgRes.getStatus().equals(MsgStatus.NORMAL) || msgRes.getResult()==null || msgRes.getResult().size()==0){ MemberRoleConnRepModel memberRoleConnRepModel = new MemberRoleConnRepModel(); memberRoleConnRepModel.setMemberId(memberId); memberRoleConnRepModelService.saveInitMemberRole(memberRoleConnRepModel); msgRes = memberRoleConnRepModelService.queryByList(mm); } List<Long> roleIds = new ArrayList<Long>(); List<Long> rankIds = new ArrayList<Long>(); for(MemberRoleConnRepModel me : msgRes.getResult()){ roleIds.add(me.getRoleId()); rankIds.add(me.getRankId()); } if(roleIds==null || roleIds.size() ==0 || rankIds==null || rankIds.size() ==0 ){ return super.returnParamsError("此会员没有角色!"); } MemberFreedomRepModel memberFreedom = new MemberFreedomRepModel(); memberFreedom.setRankIds(rankIds); memberFreedom.setRoleIds(roleIds); memberFreedom.setMemberId(memberId); memberFreedom.setFreedomType(freedomType); memberFreedom.setPaymentTypeId(paymentId); memberFreedom.setNoTime(DateUtils.getCurrentDateString()); List<MemberFreedomRepModel> list = super.memberFreedomRepMapper.getMFListByPay(memberFreedom) ; if(list==null || list.size() ==0 ){ return super.returnCorrectResult("此会员暂无充值特权!"); } MemberFreedomRepModel me = list.get(0);; //充值奖励 维护的数据是这样的 100:2,200:20 如果是 冲 300 则是 2 + 20 List<String> ruleList = new ArrayList<String>(); for(String str : me.getValue().split(",")){ ruleList.add(str); } BigDecimal ps = paySend(money,ruleList); me.setPaySend(ps); //查询各特权使用记录 MemberRankFreedomLogRepModel memberRankFreedomLogRep =new MemberRankFreedomLogRepModel(); memberRankFreedomLogRep.setMemberId(me.getMemberId()); memberRankFreedomLogRep.setRoleId(me.getRoleId()); memberRankFreedomLogRep.setFreedomId(me.getFreedomId()); if(me.getTimeRang().equals("rang")){ memberRankFreedomLogRep.setOverTime(me.getEndTime()); } HashMap ma = memberRankFreedomLogRepModelService.sumUserLog( memberRankFreedomLogRep); if(ma!=null){ logger.debug(ma.get("use_num")+"=============="+ma.get("money")); //如果超过 判断是周期/限制使用次数 /限制优惠金额 则此特权无效 if( (me.getUseNum() > 0 && Double.valueOf(ma.get("use_num").toString()) >= me.getUseNum()) || (me.getMemberQuota()!=null && me.getMemberQuota().compareTo(BigDecimal.valueOf(Double.valueOf(ma.get("money").toString()))) <= 0 )){ return super.returnCorrectResult("查询会员的特权列表成功!"); }else{ me.setMemberQuota(BigDecimal.valueOf(Double.valueOf(ma.get("use_num")==null || ma.get("use_num").equals("")?"0":ma.get("use_num").toString()))); me.setMemberUseNum(BigDecimal.valueOf(Double.valueOf(ma.get("money")==null || ma.get("money").equals("")?"0":ma.get("money").toString()))); } } return super.returnCorrectResult("查询会员的特权列表成功!",me); } catch (Exception e) { logger.error(e.getMessage(), e); return super.returnException("查询会员的特权列表失败!"); } }}
<!-- sql --> <select id="getMFListByPay" resultMap="getMemberFreedomListMap" parameterType="MemberFreedomRepModel"> select cc.*,dd.* from (select cc.rank_id,cc.freedom_id,cc.time_rang,cc.begin_time,cc.end_time,cc.long_day,cc.get_time ,rr.role_id from member_rank_freedom_conn cc join (select role_id,rank_id from member_role_conn rr where rr.is_delete ='N' and rr.role_id in <foreach collection="roleIds" open="(" close=")" item="id" separator=","> #{id} </foreach> and member_id = #{memberId} ) rr on cc.rank_id = rr.rank_id where cc.is_delete ='N' and (cc.time_rang = 'all' or (cc.time_rang='rang' and cc.begin_time <= #{noTime} and #{noTime} <=end_time ) ) ) cc join (select ff.* from ( select f2.* from member_freedom f2 where f2.is_delete = 'N' and f2.freedom_type = #{freedomType} ) ff join ( (select max(ff.level) level,ff.freedom_type from member_freedom ff where ff.is_delete = 'N' and ff.freedom_type = #{freedomType} and ff.payment_type_id =#{paymentTypeId} and ff.id in (select cc.freedom_id from member_rank_freedom_conn cc where cc.rank_id in <foreach collection="rankIds" open="(" close=")" item="id" separator=","> #{id} </foreach> and cc.is_delete ='N' and (cc.time_rang = 'all' or (cc.time_rang='rang' and cc.begin_time <= #{noTime} and #{noTime}<=end_time ) ) ) group by ff.freedom_type) ) d1 on ff.freedom_type= d1.freedom_type and ff.level = d1.level ) dd on cc.freedom_id = dd.id </select>
//Mapper层 public List<MemberFreedomRepModel> getMFListByPay(MemberFreedomRepModel memberFreedomRepModel);
//model package com.j1.member.mysql.model; import java.math.BigDecimal; import java.text.Bidi; import java.util.List; import com.j1.member.mysql.entities.MemberFreedomRep; /** * * 特权明细 扩展类 * */ @SuppressWarnings("serial") public class MemberFreedomRepModel extends MemberFreedomRep { private List<Long> roleIds; private List<Long> rankIds; private String noTime; /** 特权ID **/ private Long freedomId; /** 有效时间限制(all/rang) **/ private String timeRang; /** 有效开始时间 **/ private String beginTime; /** 有效结束时间 **/ private String endTime; /** 持续时长(天) **/ private Long longDay; /** 获得时间 **/ private String getTime; /** 等级ID **/ private Long rankId; private String freedomTypeName; private Long roleId; private Long MemberId; private BigDecimal memberQuota; // 已使用限额 private BigDecimal memberUseNum; // 已使用次数 /** 冲值送的金额 */ private BigDecimal paySend = BigDecimal.ZERO; public BigDecimal getPaySend() { return paySend; } public void setPaySend(BigDecimal paySend) { this.paySend = paySend; } public Long getMemberId() { return MemberId; } public void setMemberId(Long memberId) { MemberId = memberId; } public BigDecimal getMemberQuota() { return memberQuota; } public void setMemberQuota(BigDecimal memberQuota) { this.memberQuota = memberQuota; } public BigDecimal getMemberUseNum() { return memberUseNum; } public void setMemberUseNum(BigDecimal memberUseNum) { this.memberUseNum = memberUseNum; } public List<Long> getRoleIds() { return roleIds; } public void setRoleIds(List<Long> roleIds) { this.roleIds = roleIds; } public Long getRoleId() { return roleId; } public void setRoleId(Long roleId) { this.roleId = roleId; } public Long getRankId() { return rankId; } public void setRankId(Long rankId) { this.rankId = rankId; } public Long getFreedomId() { return freedomId; } public void setFreedomId(Long freedomId) { this.freedomId = freedomId; } public String getTimeRang() { return timeRang; } public void setTimeRang(String timeRang) { this.timeRang = timeRang; } public String getBeginTime() { return beginTime; } public void setBeginTime(String beginTime) { this.beginTime = beginTime; } public String getEndTime() { return endTime; } public void setEndTime(String endTime) { this.endTime = endTime; } public Long getLongDay() { return longDay; } public void setLongDay(Long longDay) { this.longDay = longDay; } public String getGetTime() { return getTime; } public void setGetTime(String getTime) { this.getTime = getTime; } public List<Long> getRankIds() { return rankIds; } public void setRankIds(List<Long> rankIds) { this.rankIds = rankIds; } public String getNoTime() { return noTime; } public void setNoTime(String noTime) { this.noTime = noTime; } public String getFreedomTypeName() { return freedomTypeName; } public void setFreedomTypeName(String freedomTypeName) { this.freedomTypeName = freedomTypeName; } }
//测试 @Test public void test11() { MemberService service = J1SOAHessianHelper.getService(url, MemberService.class); MemberModel mm = new MemberModel(); List<Integer> list = new ArrayList<Integer>(); list.add(1851); list.add(1852); list.add(2649); mm.setMemberIdList(list); ServiceMessage<List<Member>> result = service.getMemberNameList(mm); System.out.println(JSON.toJSONString(result)); }
mybatis 循环遍历的更多相关文章
- mybatis问题。foreach循环遍历数组报错情况,及其解决方法
根据条件查询数据列表,mybatis查询代码如下 如果只查询属于特定部门拥有的数据权限.这需要用 String[ ] codes保存当前部门及其子部门的部门编码. 所以需要在mybatis中遍历编码数 ...
- To Java程序员:切勿用普通for循环遍历LinkedList
ArrayList与LinkedList的普通for循环遍历 对于大部分Java程序员朋友们来说,可能平时使用得最多的List就是ArrayList,对于ArrayList的遍历,一般用如下写法: p ...
- *使用while循环遍历数组创建索引和自增索引值
package com.chongrui.test;/* *使用while循环遍历数组 * * * */public class test { public static void main ...
- 【转】ArrayList循环遍历并删除元素的常见陷阱
转自:https://my.oschina.net/u/2249714/blog/612753?p=1 在工作和学习中,经常碰到删除ArrayList里面的某个元素,看似一个很简单的问题,却很容易出b ...
- sqlserver中的循环遍历(普通循环和游标循环)
sql 经常用到循环,下面介绍一下普通循环和游标循环 1.首先需要一个测试表数据Student
- php中的循环遍历 foreach list each
foreach语句遍历数组foreach语句用于循环遍历数组,每进行一次循环,当前数组元素的值就会被赋值给变量value(也可以是其它变量),数组指针会逐一的移动. 代码示例: foreach($ar ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转)
主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以 ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析
最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...
- php用压栈的方式,循环遍历无限级别的数组(非递归方法)
php用压栈的方式,循环遍历无限级别的数组(非递归方法) 好久不写非递归遍历无限级分类...瞎猫碰到死老鼠,发刚才写的1段代码,压栈的方式遍历php无限分类的数组... php压栈的方式遍历无限级别数 ...
随机推荐
- iOS NSURLConnection使用详解
一.整体介绍 NSURLConnection是苹果提供的原生网络访问类,但是苹果很快会将其废弃,且由NSURLSession(iOS7以后)来替代.目前使用最广泛的第三方网络框架AFNetworkin ...
- 通过google浏览器的开发者工具修改cookie值
打开一个页面F12,然后再刷新下.点到如下图位置刚可以添加或重设cookie的值.修改cookie的值时,需要注意要清除下cookie.不然修改的cookie不生效.
- Head First 设计模式读书笔记(1)-策略模式
一.策略模式的定义 策略模式定义了算法族,分别封装起来,让它们之间可以互换替换,此模式让算法的变化独立使用算法的客户. 二.使用策略模式的一个例子 2.1引出问题 某公司做了一套模拟鸭子的游戏:该游戏 ...
- OFFLINE
2013年9月22日 20:47:42 OFFLINE 今天没有网络,或许,只有没有网络才去做一些更加有意义的事情.人就是这么贱,不是么.或许已经有点强迫症的味道的了. 中午吃完饭有2个小时的休息时间 ...
- 【C#】使用Json.NET(newtonsoft)解析Json
最近做的WPF项目中,需要一个C#下的Json实现. 在Json的官网http://www.json.org/中查找,可见C#的Json工具主要有如下: 尝试了排在最前面的fastJSON,反序列化时 ...
- HTML——图片自动轮换和手动轮换
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- thinkphp 使用原生mysql语句 联合查询
<?php class DelAction extends Action { public function ml(){ // 实例化一个空模型,没有对应任何数据表 $Dao = M(); // ...
- 谷哥的小弟学后台(04)——MySQL(4)
探索Android软键盘的疑难杂症 深入探讨Android异步精髓Handler 具体解释Android主流框架不可或缺的基石 站在源代码的肩膀上全解Scroller工作机制 Android多分辨率适 ...
- eclipse安装spring tool suite插件
在实际项目开发时,如果我们创建了一个spring文件,其实也就是个xml文件,如果没有集成spring的开发工具,创建的就是一个单纯的xml文件.安装spring插件以后创建spring配置文件会方便 ...
- 【R】shiny界面
http://www.rstudio.com/shiny http://yanping.me/shiny-tutorial/#welcome