NHMicro 1.2.9 发布,支持service层的sql替换

栏目: 数据库 · 发布时间: 6年前

内容简介: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%'   

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

从入门到精通:Prezi完全解读

从入门到精通:Prezi完全解读

计育韬、朱睿楷、谢礼浩 / 电子工业出版社 / 2015-9 / 79.00元

Prezi是一款非线性逻辑演示软件,它区别于PowerPoint的线性思维逻辑;而是将整个演示内容铺呈于一张画布上,然后通过视角的转换定位到需要演示的位置,并且它的画布可以随时zoom in和zoom out,给演示者提供了一个更好的展示空间。 Prezi对于职场人士和在校学生是一个很好的发挥创意的工具,因为它的演示逻辑是非线性的,所以用它做出来的演示文稿可以如思维导图一样具有发散性,也可以......一起来看看 《从入门到精通:Prezi完全解读》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试