设为首页 加入收藏

TOP

Spring Boot 2注解使用Mybatis动态SQL
2019-02-10 22:08:30 】 浏览:72
Tags:Spring Boot 注解 使用 Mybatis 动态 SQL

1、简单SQL使用


//从***数据表获取统计数据
    @Select("select count(*) from issues where issue_type = #{type}")
    String getIssueCount(String type);


2、动态SQL使用


//获取时间段内issue详细信息(可根据项目名、开发者名、问题类型获取)
    @Select({"<script>",
            "select id,committername,type,count,projectname,file,line,message,creationdate,updatedate from issue",
            "where creationdate BETWEEN #{startDate} AND #{endDate}",
            "<if test='committer != null and committer.length &gt; 0'>",
            "AND committername IN",
            "<foreach item='item' index='index' collection='committer' open='(' close=')' separator=','>",
            "#{item}",
            "</foreach>",
            "</if>",
            "<if test='type != null and type.length &gt; 0'>",
            "AND type IN",
            "<foreach item='item' index='index' collection='type' open='(' close=')' separator=','>",
            "#{item}",
            "</foreach>",
            "</if>",
            "<if test='project != null and project.length &gt; 0'>",
            "AND projectname IN",
            "<foreach item='item' index='index' collection='project' open='(' close=')' separator=','>",
            "#{item}",
            "</foreach>",
            "</if>",
            "</script>"})
    List<IssueModel> getDetailIssue(@Param("startDate") String startDate, @Param("endDate")String endDate,
                                    @Param("committer") String[] committer, @Param("type") String[] type,
                                    @Param("project") String[] project);


知识点:


(1)注解写动态SQL,用<script>标签包围,然后像xml语法一样书写。


(2)SQL的拼接可以使用+号,也可以使用逗号。我这里使用的是逗号,要使用+号可以把<script>前后的大括号去掉。


(2)实现IN查询中 > 符号需要转义为 &gt; ,其中foreach的collection直接写成@param中的值即可。


(3)这是一种使用注解完全替代XML的方法,稍微复杂的SQL语句推荐使用XML方式。



编程开发网
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Java设计模式之观察者模式 下一篇用Python实现数据结构之二叉搜索树