内容简介:NHMicro 1.2.9 发布,此版本支持在service层做sql模板替换后的增删改查操作MicroServiceTemplateSupport类中添加方法这些方法执行sql支持参数替换
NHMicro 1.2.9 发布,此版本支持在service层做 sql 模板替换后的增删改查操作
MicroServiceTemplateSupport类中添加方法
public Map getInfoList4PageServiceByRep(String countSql,String sql, Map paramMap, Map pageMap) public Integer updateInfoServiceByRep(String sql,Map paramMap) public List getInfoListAllServiceByReq(String sql,Map paramMap) public Map getSingleInfoServiceByRep(String sql,Map requestParamMap)
这些方法执行sql支持参数替换
替换的语法是使用velocity语法
例如:
判断是否为null #if(${param.p1})
判断是否为"" #if(${param.p1}!='')
判断不为null且不为"" #if($!{param.p1}!='')
#sqlreplace是MicroServiceTemplate中的特殊标记,用来做?占位符替换,类似mybatis中的#替换符。使用#sqlreplace时会在返回的placeList中追加参数值。
例如以下的代码:
Map paramMap=new HashMap(); paramMap.put("p1", "1"); paramMap.put("p2", "2"); paramMap.put("p3", "3"); paramMap.put("p4", "4"); paramMap.put("p5", "5"); String sql= "select * from aaa where 1=1"+ "#if(\${param.p1})"+ " and c1='\${param.p2}' "+ "#end"+ "#if(\${param.p2})"+ " and c2= #sqlreplace(\${param.p2}) "+ "#end"+ "#if(\${param.p3})"+ " and c3 like '%\${param.p3}%' "+ "#end" ; getInfoListAllServiceByReq(sql, paramMap);
返回如下的sql替换结果
实际getInfoListAllServiceByReq方法内部执行的sql是:
select * from aaa where 1=1and c1=1 and c2=? and c3 like '%3%'
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- NHMicro 1.2.9 发布,支持 Service 层的 SQL 替换
- CSS 基础:块级元素、行内元素、替换元素、非替换元素
- Vim 中怎么将目标字符替换成新行以及如何替换换行符
- PowerShell正则替换实战
- 阿里开源软件替换指南
- 【译】逐步替换Sass
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
UNIX系统编程: 通信、并发与线程
【美】Kay Robbins、Steve Robbins / 师蓉 / 电子工业出版社 / 2018-5 / 198
《UNIX系统编程: 通信、并发与线程》是一本基于最新UNIX标准的完备的参考书,对UNIX编程的要点进行了清晰易懂的介绍,从一些用于说明如何使用系统调用的短小代码段开始,逐渐过渡到能帮助读者扩展自己技能水平的实际项目中。《UNIX系统编程: 通信、并发与线程》中对通信、并发和线程问题进行了深入探讨,对复杂的概念(如信号和并发)进行了全面且清晰的解释,还覆盖了与文件、信号、信号量、POSIX线程和......一起来看看 《UNIX系统编程: 通信、并发与线程》 这本书的介绍吧!