mybatis中注解与xml配置的对应关系和对比分析

这篇文章主要介绍了mybatis中注解与xml配置的对应关系和对比分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

注解与xml配置的对应关系

mybatis中注解就是简单不需要写配置文件,适合简单的数据处理,理解起来比较容易,不动态生成sql时候可以用用。

需要绑定,有些时候不如配置文件配置文件扩展强。 选择合适的方式应用在合适的场景,注解主要应用于sql语句比较简单容易理解的情况下可读性高;生成动态sql时用xml配置文件要更简洁,扩展性强

常用的注解和xml的对应关系

@CacheNamespace 类

@CacheNamespaceRef 类

@Results 方法

@Result 方法

@One 方法

@Many 方法

@select

@Insert

@Update

@Delete 方法

@InsertProvider 允许创建动态sql

@UpdateProvider 允许创建动态sql

@DeleteProvider 允许创建动态sql

@SelectProvider 允许创建动态sql

@Param 参数 N/A 如果你的映射器的方法需要多个参数, 这个注解可以被应用于映射器的方法 参数来给每个参数一个名字。否则,多 参数将会以它们的顺序位置来被命名 (不包括任何 RowBounds 参数) 比如。 #{param1} , #{param2} 等 , 这 是 认 的 。 使用 @Param(“person”),参数应该被命名为 #{person}。

@Options 方法 映射语句的属性 这个注解提供访问交换和配置选项的 宽广范围, 它们通常在映射语句上作为 属性出现。 而不是将每条语句注解变复 杂,Options 注解提供连贯清晰的方式 来访问它们

注解样例和xml配置样例

举几个比较典型和常用的

一对一关联查询

注解方式

@Select("select * from authority") @Results(id="au", value=@Result(column="uid", property="user", one=@One(select="findUserByid", fetchType=FetchType.LAZY))) List findAll();

@Select里面填写要查询的主表的sql语句

@Results里面映射一个id="au"的返回结果集

value=@Result()表示某一属性的映射关系

column为对应从表的外键名

property为主表实体类的从表实体类属性

one表示一对一映射

fetchType=FetchType.LAZY表示为惰性加载,当查询的结构数据需要用到从表的数据才会调用select中的从表的查询方法

select为关联查询的另一个从表的查询方法

uid为select里的参数

findUserByid为mapper中定义的方法

@Select("select * from user where id = #{id}") User findUserByid(int id);

方法可以在xml中配置也可以在本方法中用注解配置

xml中配置方式

select * from authority select * from user where id= #{id}

测试方法

@Test public void testA(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); mapper.findAll().get(0).getUser(); }

一对多关联查询

xml配置方式

select * from user where username = #{username} select * from authority where uid = #{uid}

注解方式

@Select("select * from user where username = #{username}") @Results(id="user", value=@Result(column="id", property="authoritieList", many=@Many(fetchType=FetchType.LAZY, select="findAuthorityByUid"))) User findUserByUserName(String username); @Select("select * from authority where uid = #{uid}") List findAuthorityByUid(int uid);

many表示一对多映射

测试方法

@Test public void testB(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); mapper.findUserByUserName("admin").getAuthoritieList(); }

动态sql

注解方式

@SelectProvider(type=AuthorityProvider.class,method="returnSelectsql") List findByIdAndUid(Authority authority); class AuthorityProvider{ public String returnSelectsql(Authority authority){ sql sql = new sql(){{ SELECT("*"); FROM("authority"); if(authority.getId() != 0){ WHERE("id = " + authority.getId()); } if(authority.getUid() != 0){ WHERE("uid = " + authority.getUid()); } }}; return sql.toString(); } } //用XXXProvider的注解是动态生成sql语句的, //type=AuthorityProvider.class为生成动态语句的具体类 //method="returnSelectsql"为生成动态语句的方法 //sql类为动态生成sql的类

测试方法

@Test public void testC(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); Authority authority = new Authority(); mapper.findByIdAndUid(authority); //执行此语句返回的sql语句为DEBUG [main] - ==> Preparing: SELECT * FROM authority authority.setId(1); mapper.findByIdAndUid(authority); //执行此语句返回的sql语句为DEBUG [main] - ==> Preparing: SELECT * FROM authority WHERE (id = 1) authority.setUid(2); mapper.findByIdAndUid(authority); //执行此语句返回的sql语句为DEBUG [main] - ==> Preparing: SELECT * FROM authority WHERE (id = 1 AND uid = 2) }

mybatis 注解和xml 优缺点

xml:

增加了xml文件修改麻烦,条件不确定(ifelse判断),容易出错,特殊转义字符比如大于小于

注释:

复杂sql不好用,搜集sql不方便,管理不方便,修改需重新编译

#和$区别:

相同

都是对参数进行标记的符号

#是预编译,防止sql注入

$ 相当于一个占位符,不能防止sql注入

小知识:

如果字段有关键字,则可以用反单引号修饰 比如desc-》`desc` 这样就不会报错了

resultType 只有和对象属性一样才能映射成功

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...