您好,欢迎来到纷纭教育。
搜索
您的当前位置:首页MyBatis 接口注解方式代替mapper.xml

MyBatis 接口注解方式代替mapper.xml

来源:纷纭教育

https:///m0_38068812/article/details/86566929

 

  或者

 1. 代码实现字段的映射

public interface IUserMapper {
@Select({"SELECT * from user" } )
//@ResultMap("basicMap") // 此处可以直接使用mapper.xml中
@Results({
@Result(column = "d_id",property = "id"),
@Result(column = "d_username",property = "userName"),
@Result(column = "d_password",property = "password"),
@Result(column = "d_age",property = "age"),
@Result(column = "d_name",property = "name")
})
List<User> getList1();
}
 

 2. 动态SQL语句


@Mapper
public interface IUserMapper {
//使用UserProvider类的findUserById方法来生成sql
@SelectProvider(type = UserProvider.class, method = "findUserById")
public List<User> findUserById(User user);

class UserProvider {
  public String findUserById(User user) {
    String sql = "SELECT * FROM user";
   if(user.getId()!=null){
      sql += " where id = #{id}";
   }
    return sql;
   }
}

 

3. 结构化SQL

public String findUserById(User user) {    
      return new SQL(){{    
                SELECT("id,name");    
                SELECT("other");    
                FROM("user");    
                if(user.getId()!=null){    
                    WHERE("id = #{id}");    
                }    
                if(user.getName()!=null){    
                    WHERE("name = #{name}");    
                } 
       }}.toString(); //从这个toString可以看出,其内部使用高效的StringBuilder实现SQL拼接    
} 

 

mybatis语句构造器

  

mybatis plus 的条件构造器

转载于:https://www.cnblogs.com/lhuser/p/11570620.html

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- fenyunshixun.cn 版权所有 湘ICP备2023022495号-9

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务