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


Posted in Java/Android onAugust 04, 2021

注解与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配置样例

举几个比较典型和常用的

一对一关联查询

注解方式

@Select("select * from authority")
 @Results(id="au",
 value=@Result(column="uid",
      property="user",
      one=@One(select="findUserByid",
           fetchType=FetchType.LAZY)))
 List<Authority> 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中配置方式

<resultMap type="com.jt.mybatis.entity.Authority" id="au">
    <association property="user" column="uid" javaType="com.jt.mybatis.entity.User"      select="findByUserId">
    </association>
</resultMap>

<select id="findAll" resultMap="au">
  select * from authority
</select>

<select id="findUserByid" resultType="com.jt.mybatis.entity.User">
  select * from user where id= #{id}
</select>

测试方法

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

一对多关联查询

xml配置方式

<resultMap type="com.jt.mybatis.entity.User" id="user">
      <id column="id" property="id" />
      <collection property="authoritieList" column="id"
       fetchType="lazy" select="findAuthorityByUid">
       <id column="id" property="id" />
      </collection>
    </resultMap>

 <select id="findUserByUserName" resultMap="user">
  select * from user
  where username = #{username}
 </select>
 
 <select id="findAuthorityByUid" resultType="com.jt.mybatis.entity.Authority">
  select * from
  authority where uid = #{uid}
 </select>

注解方式

@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<Authority> 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<Authority> 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 只有和对象属性一样才能映射成功

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Java/Android 相关文章推荐
每日六道java新手入门面试题,通往自由的道路
Jun 30 Java/Android
分析ZooKeeper分布式锁的实现
Jun 30 Java/Android
Java 语言中Object 类和System 类详解
Jul 07 Java/Android
mybatis 获取无数据的字段不显示的问题
Jul 15 Java/Android
一篇文章带你学习Mybatis-Plus(新手入门)
Aug 02 Java/Android
Java获取e.printStackTrace()打印的信息方式
Aug 07 Java/Android
java中用float时,数字后面加f,这样是为什么你知道吗
Sep 04 Java/Android
MyBatis-Plus 批量插入数据的操作方法
Sep 25 Java/Android
Java生成日期时间存入Mysql数据库的实现方法
Mar 03 Java/Android
Java并发编程之原子性-Atomic的使用
Mar 16 Java/Android
Java中生成微信小程序太阳码的实现方案
Jun 01 Java/Android
java实现web实时消息推送的七种方案
Jul 23 Java/Android
浅谈sql_@SelectProvider及使用注意说明
Aug 04 #Java/Android
mybatis3中@SelectProvider传递参数方式
Aug 04 #Java/Android
浅谈Java父子类加载顺序
Aug 04 #Java/Android
浅谈spring boot使用thymeleaf版本的问题
Aug 04 #Java/Android
Java后台生成图片的完整步骤
Aug 04 #Java/Android
在Spring-Boot中如何使用@Value注解注入集合类
Aug 02 #Java/Android
SpringBoot整合RabbitMQ的5种模式实战
You might like
PHP字符串处理的10个简单方法
2010/06/30 PHP
php算开始时间到过期时间的相隔的天数
2011/01/12 PHP
php中将html中的br换行符转换为文本输入中的换行符
2013/03/26 PHP
PHP获取数组中重复最多的元素的实现方法
2014/11/11 PHP
Yii2.0中的COOKIE和SESSION用法
2016/08/12 PHP
phalcon model在插入或更新时会自动验证非空字段的解决办法
2016/12/29 PHP
PHP面向对象程序设计之构造方法和析构方法详解
2019/06/13 PHP
PHP开发API接口签名生成及验证操作示例
2020/05/27 PHP
javascript不同页面传值的改进版
2008/09/30 Javascript
浅析javascript闭包 实例分析
2010/12/25 Javascript
JavaScript语言对Unicode字符集的支持详解
2014/12/30 Javascript
JavaScript内存管理介绍
2015/03/13 Javascript
JS实现设置ff与ie元素绝对位置的方法
2016/03/08 Javascript
AngularJS基础 ng-paste 指令简单示例
2016/08/02 Javascript
酷! 不同风格页面布局幻灯片特效js实现
2021/02/19 Javascript
jQuery如何封装输入框插件
2016/08/19 Javascript
javascript经典特效分享 手风琴、轮播图、图片滑动
2016/09/14 Javascript
详解Angular的双向数据绑定(MV-VM)
2016/12/26 Javascript
JS中绑定事件顺序(事件冒泡与事件捕获区别)
2017/01/24 Javascript
详谈jQuery中的一些正则匹配表达式
2017/03/08 Javascript
vue中的使用token的方法示例
2020/03/10 Javascript
Vue跨域请求问题解决方案过程解析
2020/08/07 Javascript
Python标准库之sqlite3使用实例
2014/11/25 Python
Python Sqlite3以字典形式返回查询结果的实现方法
2016/10/03 Python
对python抓取需要登录网站数据的方法详解
2018/05/21 Python
Python字符串对象实现原理详解
2019/07/01 Python
GDAL 矢量属性数据修改方式(python)
2020/03/10 Python
python中Array和DataFrame相互转换的实例讲解
2021/02/03 Python
html5的自定义data-*属性与jquery的data()方法的使用
2014/07/02 HTML / CSS
美国顶级防滑鞋:Shoes For Crews
2017/03/27 全球购物
洛佩桑酒店官方网站:Lopesan Hotels
2019/04/15 全球购物
波兰在线运动商店:YesSport
2020/07/23 全球购物
2015年数学教研组工作总结
2015/05/23 职场文书
《学会看病》教学反思
2016/02/17 职场文书
幼儿园语言教学反思
2016/02/23 职场文书
SQL实现LeetCode(196.删除重复邮箱)
2021/08/07 MySQL