经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
mybatis中注解与xml配置的对应关系和对比分析
来源:jb51  时间:2021/8/4 9:10:18  对本文有异议

注解与xml配置的对应关系

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

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

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

  • @CacheNamespace 类 <cache>
  • @CacheNamespaceRef 类 <cacheRef>
  • @Results 方法 <resultMap>
  • @Result 方法 <result> <id>
  • @One 方法 <association>
  • @Many 方法 <collection>
  • @select <select>
  • @Insert <insert>
  • @Update <update>
  • @Delete 方法 <delete>
  • @InsertProvider <insert> 允许创建动态SQL
  • @UpdateProvider <update> 允许创建动态SQL
  • @DeleteProvider <delete> 允许创建动态SQL
  • @SelectProvider <select> 允许创建动态SQL
  • @Param 参数 N/A 如果你的映射器的方法需要多个参数, 这个注解可以被应用于映射器的方法 参数来给每个参数一个名字。否则,多 参数将会以它们的顺序位置来被命名 (不包括任何 RowBounds 参数) 比如。 #{param1} , #{param2} 等 , 这 是 默 认 的 。 使用 @Param(“person”),参数应该被命名为 #{person}。
  • @Options 方法 映射语句的属性 这个注解提供访问交换和配置选项的 宽广范围, 它们通常在映射语句上作为 属性出现。 而不是将每条语句注解变复 杂,Options 注解提供连贯清晰的方式 来访问它们

注解样例和xml配置样例

举几个比较典型和常用的

一对一关联查询

注解方式

  1. @Select("select * from authority")
  2. @Results(id="au",
  3. value=@Result(column="uid",
  4. property="user",
  5. one=@One(select="findUserByid",
  6. fetchType=FetchType.LAZY)))
  7. List<Authority> findAll();
  • @Select里面填写要查询的主表的sql语句
  • @Results里面映射一个id="au"的返回结果集
  • value=@Result()表示某一属性的映射关系
  • column为对应从表的外键名
  • property为主表实体类的从表实体类属性名
  • one表示一对一映射
  • fetchType=FetchType.LAZY表示为惰性加载,当查询的结构数据需要用到从表的数据才会调用select中的从表的查询方法
  • select为关联查询的另一个从表的查询方法
  • uid为select里的参数
  • findUserByid为mapper中定义的方法
  1. @Select("select * from user where id = #{id}")
  2. User findUserByid(int id);

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

xml中配置方式

  1. <resultMap type="com.jt.mybatis.entity.Authority" id="au">
  2. <association property="user" column="uid" javaType="com.jt.mybatis.entity.User" select="findByUserId">
  3. </association>
  4. </resultMap>
  5.  
  6. <select id="findAll" resultMap="au">
  7. select * from authority
  8. </select>
  9.  
  10. <select id="findUserByid" resultType="com.jt.mybatis.entity.User">
  11. select * from user where id= #{id}
  12. </select>

测试方法

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

一对多关联查询

xml配置方式

  1. <resultMap type="com.jt.mybatis.entity.User" id="user">
  2. <id column="id" property="id" />
  3. <collection property="authoritieList" column="id"
  4. fetchType="lazy" select="findAuthorityByUid">
  5. <id column="id" property="id" />
  6. </collection>
  7. </resultMap>
  8.  
  9. <select id="findUserByUserName" resultMap="user">
  10. select * from user
  11. where username = #{username}
  12. </select>
  13. <select id="findAuthorityByUid" resultType="com.jt.mybatis.entity.Authority">
  14. select * from
  15. authority where uid = #{uid}
  16. </select>

注解方式

  1. @Select("select * from user where username = #{username}")
  2. @Results(id="user",
  3. value=@Result(column="id",
  4. property="authoritieList",
  5. many=@Many(fetchType=FetchType.LAZY,
  6. select="findAuthorityByUid")))
  7. User findUserByUserName(String username);
  8.  
  9. @Select("select * from authority where uid = #{uid}")
  10. List<Authority> findAuthorityByUid(int uid);

many表示一对多映射

测试方法

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

动态sql

注解方式

  1. @SelectProvider(type=AuthorityProvider.class,method="returnSelectSQL")
  2. List<Authority> findByIdAndUid(Authority authority);
  3. class AuthorityProvider{
  4. public String returnSelectSQL(Authority authority){
  5. SQL sql = new SQL(){{
  6. SELECT("*");
  7. FROM("authority");
  8. if(authority.getId() != 0){
  9. WHERE("id = " + authority.getId());
  10. }
  11. if(authority.getUid() != 0){
  12. WHERE("uid = " + authority.getUid());
  13. }
  14. }};
  15. return sql.toString();
  16. }
  17. }
  18. //用XXXProvider的注解是动态生成sql语句的,
  19. //type=AuthorityProvider.class为生成动态语句的具体类
  20. //method="returnSelectSQL"为生成动态语句的方法
  21. //SQL类为动态生成sql的类

测试方法

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

mybatis 注解和xml 优缺点

xml:

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

注释:

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

#和$区别:

相同

  • 都是对参数进行标记的符号
  • #是预编译,防止sql注入
  • $ 相当于一个占位符,不能防止sql注入

小知识:

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

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

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号