设为首页 收藏本站
查看: 2552|回复: 0

[经验分享] MyBatis映射文件的resultMap如何做表关联

[复制链接]

尚未签到

发表于 2016-11-27 06:40:26 | 显示全部楼层 |阅读模式
  MyBatis的核心是其映射文件,SqlMap文件,里面配置了项目中用到了什么SQL语句,和数据库相关的逻辑都在这个映射文件里.顾名思义,映射文件就是对Java对象和SQL的映射.这里简单介绍一下映射文件中resultMap的用法:resultMap – 它描述如何将结果集映射到Java对象.
resultMap属性:type为java实体类;id为此resultMap的标识:<resultMap id="BaseResultMap" type="com.test.mybatis.vo.MybatisOrder" >
resultMap的子元素:
id – 一般对应到数据库中该行的ID,设置此项可以提高Mybatis性能.
result – 映射到JavaBean 的某个"简单类型"属性,String,int等.
association – 映射到JavaBean 的某个"复杂类型"属性,其他JavaBean类.
collection –复杂类型集合,a collection of complex types
比如现在有一个Order表,Customer表和OrderItem表,它们之间的关系为:一个Order关联到一个Customer(单向关联),一个Order有多个OrderItem(双向关联).
对应的Java对象文件为,
 
[html] view plaincopy 



  • public class MybatisOrder {  
  •     ....  
  •     private Mybatiscustomer customer;  
  •     private List<MybatisOrderItem> itemList;  
  •     ....  
  • public class MybatisOrderItem {  
  •     private MybatisOrder order;  
  •     ...  

  对应的mapper文件为:
MybatiscustomerMapper.xml:
[html] view plaincopy 



  • <resultMap id="AssociationSelectMap" type="com.test.mybatis.vo.MybatisOrder" >  
  •     <id column="ORDERID" property="orderid" jdbcType="DECIMAL" />  
  •     <result column="ORDERTYPE" property="ordertype" jdbcType="VARCHAR" />  
  •     <result column="ORDERDATE" property="orderdate" jdbcType="DATE" />  
  •     <association property="customer" column="CUSTOMERID"   
  •         select="com.test.mybatis.mapper.MybatiscustomerMapper.getCustomerByID"/>   
  •     <collection property="itemList" column="ORDERID" javaType="ArrayList" ofType="MybatisOrderItem"   
  •         select="com.test.mybatis.mapper.MybatisOrderItemMapper.selectItemsByOrderID"/>  
  • </resultMap>  
  • <select id="getOrderByID" resultMap="AssociationSelectMap" parameterType="java.math.BigDecimal" >  
  •     select *from MYBATISORDER where ORDERID = #{orderid,jdbcType=DECIMAL}  
  • </select>  

  MybatisOrderItemMapper.xml:
[html] view plaincopy 



  •  <resultMap id="AssociationMap" type="com.test.mybatis.vo.MybatisOrderItem" >  
  •    <id column="ITEMID" property="itemid" jdbcType="DECIMAL" />  
  •    <result column="ITEMTYPE" property="itemtype" jdbcType="VARCHAR" />  
  •    <result column="ITEMQUANTITY" property="itemquantity" jdbcType="VARCHAR" />  
  •    <result column="ITEMCOST" property="itemcost" jdbcType="VARCHAR" />  
  •    <association property="order" column="ORDERID"   
  • select="com.test.mybatis.mapper.MybatisOrderMapper.getOrderByID"/>   
  •  </resultMap>  
  •  <select id="selectItemByID" resultMap="AssociationMap" parameterType="java.math.BigDecimal" >  
  •    select *from MYBATISORDERITEMwhere ITEMID = #{itemid,jdbcType=DECIMAL}  
  •  </select>  

  MybatiscustomerMapper.xml:因为不和别的表做关联,只有简单的id,result配置.
[html] view plaincopy 



  • <resultMap id="BaseResultMap" type="com.test.mybatis.vo.Mybatiscustomer" >  
  •   <id column="ID" property="id" jdbcType="DECIMAL" />  
  •   <result column="NAME" property="name" jdbcType="VARCHAR" />  
  • </resultMap>  
  • <select id="getCustomerByID" resultMap="BaseResultMap" parameterType="java.math.BigDecimal" >  
  •   select *from MYBATISCUSTOMER where ID = #{id,jdbcType=DECIMAL}  
  • </select>  

 
  MybatisOrderMapper的getOrderByID会先从MYBATISORDER取数据,然后根据CUSTOMERID调用MybatiscustomerMapper.getCustomerByID,然后根据ORDERID调用MybatisOrderItemMapper.selectItemsByOrderID,对应每一条MYBATISORDER数据,都会分别访问另外两个表各一次.
通过将association和collection的select功能替换为resultMap,再用join方式的SQL可以用一条SQL语句将关联数据取出来:
 
[html] view plaincopy 



  •  <resultMap id="AssociationResultMap" type="com.test.mybatis.vo.MybatisOrder" >  
  •    <id column="ORDERID" property="orderid" jdbcType="DECIMAL" />  
  •    <result column="ORDERTYPE" property="ordertype" jdbcType="VARCHAR" />  
  •    <result column="ORDERDATE" property="orderdate" jdbcType="DATE" />  
  •   
  • <association property="customer" column="CUSTOMERID"   
  •     resultMap="com.test.mybatis.mapper.MybatiscustomerMapper.BaseResultMap"/>   
  • <collection property="itemList" column="ORDERID" javaType="ArrayList"   
  •     ofType="com.test.mybatis.vo.MybatisOrderItem"   
  •     resultMap="com.test.mybatis.mapper.MybatisOrderItemMapper.BaseResultMap"/>  
  •  </resultMap>  
  •  <select id="getOrderAssociation" parameterType="String" resultMap="AssociationResultMap">    
  •     SELECT *    
  •       FROM mybatisOrder ord LEFT JOIN mybatiscustomer customer ON ord.customerId = customer.ID   
  •       LEFT JOIN mybatisOrderItem item ON ord.orderid = item.orderid   
  •      WHERE ord.orderid = #{id}  
  •   </select>   

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-305882-1-1.html 上篇帖子: MyBatis映射文件的resultMap如何做表级联查询 下篇帖子: 最简单的mybatis增删改查样例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表