NHMicro 1.2.9 发布,支持 Service 层的 SQL 替换

栏目: 软件资讯 · 发布时间: 6年前

内容简介:NHMicro 1.2.9 发布,此版本支持在service层做sql模板替换后的增删改查操作 MicroServiceTemplateSupport类中添加方法 public Map getInfoList4PageServiceByRep(String countSql,String sql, Map paramMap, Map ...

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%'
 


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

查看所有标签

猜你喜欢:

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

人人都是产品经理

人人都是产品经理

苏杰 / 电子工业出版社 / 2010年4月 / 45.00元

这是写给“-1到3岁的产品经理”的书,适合刚入门的产品经理、产品规划师、需求分析师,以及对做产品感兴趣的学生,用户体验、市场运营、技术部门的朋友们,特别是互联网、软件行业。作为一名“4岁的产品经理”,作者讲述了过去3年的经历与体会,与前辈们的书不同,本书就像你走到作者身边,说“嗨哥们!晚上有空吃个饭么,随便聊聊做产品的事吧”,然后作者说“好啊”。 书名叫“人人都是产品经理”,是因为作者觉得过......一起来看看 《人人都是产品经理》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具