zoukankan      html  css  js  c++  java
  • mybatis使用注解替代xml配置,动态生成Sql

    mybatis使用注解替代xml配置时,遇到判断条件是否为null或者为空时,@Select很难搞定,不知道怎么办?

    mybatis3中增加了使用注解来配置Mapper的新特性,使用 SelectProvider来动态生成sql。

    典型的使用场景

    1. 无参数@SelectProvide方法
    在Mapper接口方法上和@SelectProvide指定类方法上,均无参数:
    UserMapper.java:

    1     @SelectProvider(type = SqlProvider.class, method = "selectAllUser")
    2     @ResultMap("userMap")
    3     public List<User> getAllUser();
    SqlProvider.java:
    1     public String selectAllUser() {
    2         return "select * from user";
    3     }
     
    2.单个参数使用@SelectProvider

    2.1.没有@Param注解的单个参数使用@SelectProvider

    @SelectProvider是声明在方法基本上的,这个方法定义在Mapper对应的的interface上。
    1 public interface UserMapper {
    2     @SelectProvider(type = SqlProvider.class, method = "selectUser")
    3     @ResultMap("userMap")
    4     public User getUser(long userId);
    5 }
    上例中是个很简单的Mapper接口,其中定义了一个方法:getUser,这个方法根据提供的用户id来查询用户信息,并返回一个User实体bean。
    这是一个很简单很常用的查询场景:根据key来查询记录并将结果封装成实体bean。其中:
    @SelectProvider注解用于生成查询用的sql语句,有别于@Select注解,@SelectProvide指定一个Class及其方法,并且通过调用Class上的这个方法来获得sql语句。在我们这个例子中,获取查询sql的方法是SqlProvider.selectUser。
    @ResultMap注解用于从查询结果集RecordSet中取数据然后拼装实体bean。
     
    @SelectProvide中type参数指定的Class类,必须要能够通过无参的构造函数来初始化。
    @SelectProvide中method参数指定的方法,必须是public的,返回值必须为String,可以为static。
    1 public class SqlProvider {
    2     public String selectUser(long userId) {
    3         return "select * from user where userId=" + userId;
    4     }
    5 }

    2.2.带有@Param注解一个参数的@SelectProvide方法
    对于只有一个参数的情况,可以直接使用,参见前面的getUser和selectUser。
    但是,如果在getUser方法中,对userId方法使用了@Param注解的话,那么相应selectUser方法必须接受Map<String, Object>做为参数:
    UserMapper.java:

    1     @SelectProvider(type = SqlProvider.class, method = "selectUser2")
    2     @ResultMap("userMap")
    3     public User getUser2(@Param("userId") long userId);

    SqlProvider.java:

    1     public String selectUser2(Map<String, Object> para) {
    2         return "select * from user where userId=" + para.get("userId");
    3     }


    3.多参数的@SelectProvide方法
    在超过一个参数的情况下,@SelectProvide方法必须接受Map<String, Object>做为参数,
    如果参数使用了@Param注解,那么参数在Map中以@Param的值为key,如下例中的userId;
    如果参数没有使用@Param注解,那么参数在Map中以参数的顺序为key,如下例中的password:

    UserMapper.java:
    1     @SelectProvider(type = SqlProvider.class, method = "selectUserCheck")
    2     @ResultMap("userMap")
    3     public User getUserCheck(@Param("userId") long userId, String password);
    SqlProvider.java:
    1     public String selectUserCheck(Map<String, Object> para) {
    2         return "select * from user where userId=" + para.get("userId") + " and password='" + para.get("1") + "'";
    3     }

    4.一些限制
    在Mapper接口和@SelectProvide方法类中,不要使用重载,也就是说,不要使用方法名相同参数不同的方法,以避免发生诡异问题。
     
    参考文献:
    【1】http://www.blogjava.net/dbstar/archive/2011/08/08/355825.html
  • 相关阅读:
    2013.4.15 Particle Swarm Optimization with Skyline Operator for Fast Cloudbased Web Service Composition
    Adaptive service composition in flexible processes
    2013.4.13 DomainSpecific Service Selection for Composite Services
    2013.4.14 Modeling and Algorithms for QoSAware Service Composition in VirtualizationBased Cloud Computing
    2013.5.29 Towards Networkaware Service Composition in the Cloud
    Efficient algorithms for Web services selection with endtoend QoS constraints
    SQL Server中常用的SQL语句
    接口限流自定义注解
    linux服务器生产环境搭建
    MVEL自定义函数重复掉用报错:duplicate function
  • 原文地址:https://www.cnblogs.com/davidwang456/p/6838020.html
Copyright © 2011-2022 走看看