ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

MyBatis结果集映射源码

2022-06-03 13:35:51  阅读:141  来源: 互联网

标签:映射 List ResultMap 源码 自动 private MyBatis id


MyBatis作为持久层框架,它最牛逼的地方就是将查询的结果集与Java对象映射,让我们解放双手,不用操心JDBC的类型和Java的类型关系的处理,那它怎么实现的呢?

先介绍下ResultMap,ResultMapping

ResultMap&ResultMapping

ResultMap就是平常我们编写的Mapper文件中的某条SQL语句的对象,就是下面这个

   <select id="getBlog" resultType="org.apache.ibatis.demo.Blog">
        select *
        from Blog
        where id = #{id}
    </select>

ResultMap所拥有的属性

public class ResultMap {
  private String id;
  private Class<?> type;
  // 结果映射行数
  private List<ResultMapping> resultMappings;
  private List<ResultMapping> idResultMappings;
  private List<ResultMapping> constructorResultMappings;
  private List<ResultMapping> propertyResultMappings;
  private Set<String> mappedColumns;
  private Discriminator discriminator;
  // 有嵌套的结果集?
  private boolean hasNestedResultMaps;
  // 有嵌套查询?
  private boolean hasNestedQueries;
  // 是否自动映射
  private Boolean autoMapping;
}

 

两种映射,分别是自动映射和手动映射。

自动映射

 Sql的列名和 Model 中的字段名称是一样的时候(不区分大小写),mybatis 内部会进行自动映射。

自动映射分为三个等级:NONE,PARTIAL(默认),FULL

  • MyBatis中映射范围分为两种,一种是全局配置的自动映射,还有就是当前ResultMap的自动映射

手动映射

  • 手动映射根据自己设定的ResultMap映射。

标签:映射,List,ResultMap,源码,自动,private,MyBatis,id
来源: https://www.cnblogs.com/JoJo1021/p/16339782.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有