设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客
LUPA开源社区 首页 业界资讯 软件追踪 查看内容

NHMicro1.2.9发布,支持Service层的SQL替换

2019-5-15 10:30| 发布者: joejoe0332| 查看: 91| 评论: 0|原作者: oschina|来自: oschina

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

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

酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187  

返回顶部