MyBatis之ResultMap的association和collection标签详解(mybaties resultmap)

  本篇文章为你整理了MyBatis之ResultMap的association和collection标签详解(mybaties resultmap)的详细内容,包含有mybatis result maps collection mybaties resultmap mybatis的resultmap和resulttype mybatis result标签 MyBatis之ResultMap的association和collection标签详解,希望能帮助你了解 MyBatis之ResultMap的association和collection标签详解。

  MyBatis 创建时的一个思想是:数据库不可能永远是你所想或所需的那个样子。 我们希望每个数据库都具备良好的第三范式或 BCNF 范式,可惜它们并不都是那样。 如果能有一种数据库映射模式,完美适配所有的应用程序,那就太好了,但可惜也没有。 而 ResultMap 就是 MyBatis 对这个问题的答案。

  二、ResultMap 的属性列表

  
autoMapping

  如果设置这个属性,MyBatis 将会为本结果映射开启或者关闭自动映射。 这个属性会覆盖全局的属性 autoMappingBehavior。默认值:未设置(unset)。

  
idArg - ID 参数;标记出作为 ID 的结果可以帮助提高整体性能

  arg - 将被注入到构造方法的一个普通结果

  
id – 一个 ID 结果;标记出作为 ID 的结果可以帮助提高整体性能

  result – 注入到字段或 JavaBean 属性的普通结果

  association – 一个复杂类型的关联;许多结果将包装成这种类型
 

  嵌套结果映射 – 关联可以是 resultMap 元素,或是对其它结果映射的引用

  collection – 一个复杂类型的集合
 

  嵌套结果映射 – 集合可以是 resultMap 元素,或是对其它结果映射的引用

  discriminator – 使用结果值来决定使用哪个 resultMap

  case – 基于某些值的结果映射
 

  嵌套结果映射 – case 也是一个结果映射,因此具有相同的结构和元素;或者引用其它的结果映射

  
property

  映射到列结果的字段或属性。如果 JavaBean 有这个名字的属性(property),会先使用该属性。否则 MyBatis 将会寻找给定名称的字段(field)。 无论是哪一种情形,你都可以使用常见的点式分隔形式进行复杂属性导航。 人话为:就是你的Java实体类

  
column

  数据库中的列名,或者是列的别名。一般情况下,这和传递给 resultSet.getString(columnName) 方法的参数一样。

  
javaType

  一个 Java 类的全限定名,或一个类型别名(关于内置的类型别名,可以参考上面的表格)。 如果你映射到一个 JavaBean,MyBatis 通常可以推断类型。然而,如果你映射到的是 HashMap,那么你应该明确地指定 javaType 来保证行为与期望的相一致。

  
jdbcType

  JDBC 类型,所支持的 JDBC 类型参见这个表格之后的“支持的 JDBC 类型”。 只需要在可能执行插入、更新和删除的且允许空值的列上指定 JDBC 类型。这是 JDBC 的要求而非 MyBatis 的要求。如果你直接面向 JDBC 编程,你需要对可以为空值的列指定这个类型。

  
typeHandler

  我们在前面讨论过默认的类型处理器。使用这个属性,你可以覆盖默认的类型处理器。 这个属性值是一个类型处理器实现类的全限定名,或者是类型别名。

  
- 常用例子展示

  

 resultMap id="UsersMap" type="com.wang.test.demo.entity.User" 

 

   id property="id" column="id" jdbcType="INTEGER"/

   result property="username" column="username" jdbcType="VARCHAR"/

   result property="password" column="password" jdbcType="VARCHAR"/

   result property="role" column="role" jdbcType="VARCHAR"/

   result property="addTime" column="add_time" jdbcType="TIMESTAMP"/

   /resultMap

  

 

  五、association标签常用参数详解

  
property

  映射到列结果的字段或属性。如果用来匹配的 JavaBean 存在给定名字的属性,那么它将会被使用。否则 MyBatis 将会寻找给定名称的字段。 无论是哪一种情形,你都可以使用通常的点式分隔形式进行复杂属性导航。 人话为:你要一对一的实体类中的另一个实体类的名称

  
javaType

  一个 Java 类的完全限定名,或一个类型别名。 如果你映射到一个 JavaBean,MyBatis 通常可以推断类型。然而,如果你映射到的是 HashMap,那么你应该明确地指定 javaType 来保证行为与期望的相一致。

  
//把出版社对象当作属性

   private Publisher pub;//------重点在这里一本书对应一个出版社,这是一个出版社对象

  

 

 

  

@Data

 

  //出版社

  public class Publisher {

   private String id;

   private String name;

   private String phone;

   private String address;

  

 

  - xml演示

  

 resultMap id="rMap_book" type="com.wang.test.demo.entity.Book" 

 

   !-- 主键 property为实体类属性 column为数据库字段 jdbcType为实体类对应的jdbc类型--

   id property="id" column="b_id" jdbcType="VARCHAR" /id

   !-- 普通属性 property为实体类属性 column为数据库字段 jdbcType为实体类对应的jdbc类型--

   result property="name" column="b_name" jdbcType="VARCHAR" /result

   result property="author" column="author" jdbcType="VARCHAR" /result

   result property="price" column="price" jdbcType="VARCHAR" /result

   result property="del" column="del" jdbcType="NUMERIC" /result

   result property="publisherid" column="publisher_id" jdbcType="VARCHAR" /result

   result property="publishdate" column="publish_date" jdbcType="TIMESTAMP" /result

   !--一对一映射association property 为实体类book中的属性名字 javaType为实体类属性的类型 --

   association property="pub" javaType="com.wang.test.demo.entity.Publisher"

   id property="id" column="p_id" jdbcType="VARCHAR" /id

   result property="name" column="name" jdbcType="VARCHAR" /result

   result property="phone" column="phone" jdbcType="VARCHAR" /result

   result property="address" column="address" jdbcType="VARCHAR" /result

   /association

   /resultMap

  

 

  六、collection标签常用参数详解

  
property

  映射到列结果的字段或属性。如果用来匹配的 JavaBean 存在给定名字的属性,那么它将会被使用。否则 MyBatis 将会寻找给定名称的字段。 无论是哪一种情形,你都可以使用通常的点式分隔形式进行复杂属性导航。 人话为:你要一对一的实体类中的另一个实体类的名称

  
private String name;

   private List Student students;//----重点在这里,一个班级对应多个学生

  

 

 

  

@Data

 

  public class Student {

   private int id;

   private String name;

   private int age;

  

 

  - xml演示

  

 resultMap id="rMap_class" type="com.wang.test.demo.entity.Class" 

 

   id property="id" column="id" jdbcType="VARCHAR" /id

   result property="name" column="name" jdbcType="VARCHAR" /result

   !--一对多映射用这个 ofTyp是一对多的集合的所存放的实体类 javaType实体类的属性类型--

   collection property="students" ofType="com.wang.test.demo.entity.Student" javaType="list"

   id property="id" column="id" jdbcType="INTEGER" /id

   result property="name" column="name" jdbcType="VARCHAR" /result

   result property="age" column="age" jdbcType="INTEGER" /result

   /collection

   /resultMap

  

 

  七、jdbc Type与java Type对照表

  
这样就对ResultMap具体参数进行详细的解释,还有对association和collection标签的解释和具体演示,希望能够帮到你,一起学习,如果用到收藏一下呗!!!!

  欢迎大家关注小编的微信公众号,谢谢大家!

  以上就是MyBatis之ResultMap的association和collection标签详解(mybaties resultmap)的详细内容,想要了解更多 MyBatis之ResultMap的association和collection标签详解的内容,请持续关注盛行IT软件开发工作室。

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: