Jtti广告广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >mybatis如何实现继承映射
  • 790
分享到

mybatis如何实现继承映射

mybatis继承继承映射mybatis映射 2017-01-08 05:01:20 790人浏览 绘本
摘要

目录mybatis 继承映射类图三个实体类的代码分析mybatis xml映射文件的继承问题1、首先dao层mapper.java需要继承原来的接口  2、继承原始mapper.xml的结果映射   mybatis 继承映射 ORM框架的优

目录
  • mybatis 继承映射
    • 类图
    • 三个实体类的代码
    • 分析
  • mybatis xml映射文件的继承问题
    • 1、首先dao层mapper.java需要继承原来的接口  
    • 2、继承原始mapper.xml的结果映射   

mybatis 继承映射

ORM框架的优势在于能让我们利用面向对象的思维去操作数据库,hibernate作为重量级的ORM框架对面向对象的支持很强大。作为半自动化的mybatis,对面向对象的支持也是很完备的。这篇文章就来讨论一下如何利用mybatis实现继承映射。

类图

有一个机动车父类,它有两个子类:Car和Bus

关系模型(t_vehicle)

ORM映射有一个原则:对象模型细粒度,关系模型粗粒度。所以我们将所有的车都存储一张表里(t_vehicle),通过鉴别字段vType来区分车的类型("c"代表Car,"b"代表Bus)

三个实体类的代码

Vehicle


package com.tgb.mybatis.model; 
public class Vehicle {
	//主键id
	private String id;
	//车的名字
	private String name;
	
	public String getId() {
		return id;
	}
	
	public void setId(String id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	} 
}

Car


package com.tgb.mybatis.model; 
public class Car extends Vehicle {
	//车门的数量
	private int carDoor;
	//车的牌子
	private String band;
	
	public int getCarDoor() {
		return carDoor;
	}
	public void setCarDoor(int carDoor) {
		this.carDoor = carDoor;
	}
	public String getBand() {
		return band;
	}
	public void setBand(String band) {
		this.band = band;
	}	
}

Bus


package com.tgb.mybatis.model; 
public class Bus extends Vehicle {
	//公共汽车的容量
	private int capacity;
 
	public int getCapacity() {
		return capacity;
	} 
	public void setCapacity(int capacity) {
		this.capacity = capacity;
	}	
}

看看对“车”进行操作的Mapper接口【只关注查询】


package com.tgb.mybatis.data; 
import com.tgb.mybatis.model.Bus;
import com.tgb.mybatis.model.Car;
import com.tgb.mybatis.model.Vehicle; 
public interface VehicleMapper {
	//根据id查询机动车
	Vehicle getVechicleById(String id);
	//根据名字查询小汽车
	Car getCarByName(String name);
}

xml方式ORM映射


<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "Http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="com.tgb.mybatis.data.VehicleMapper">
    <select id="getVechicleById" resultMap="vehicleMap">
        SELECT * FROM TB_VEHICLE WHERE VID = #{id}
    </select>
    <select id="getCarByName" resultMap="vehicleMap">
        SELECT * FROM TB_VEHICLE WHERE VTYPE='c' AND VName = #{id}
    </select>
   <resultMap type="vehicle" id="vehicleMap">
       <id property="id" column="vId"/>
       <result property="name" column="vName"/>
       <discriminator javaType="string" column="vType">
           <case value="c" resultType="car">
               <result property="carDoor" column="cardoor"/>
               <result property="band" column="band"/>
           </case>
           <case value="b" resultType="bus">
               <result property="capacity" column="capacity"/>
           </case>
       </discriminator>
   </resultMap>
</mapper>

分析

其中最为关键的就是<discriminator>标签中的内容,根据鉴别字段的值自动映射成对应的子类

客户端测试代码


VehicleMapper mapper = session.getMapper(VehicleMapper.class);
Vehicle vehicle = mapper.getVechicleById("1");
System.out.println(vehicle.getName());
Car car = mapper.getCarByName("路虎007");
System.out.println(car.getBand());

很简单的一个例子,和大家分享一下。

mybatis xml映射文件的继承问题

1、首先dao层mapper.java需要继承原来的接口  

原dao层接口


public interface TagMapper {
    
    long countByExample(TagExample example);
    
    int deleteByExample(TagExample example);
}

扩展后的dao层接口


public interface TagExtendMapper extends TagMapper {
    ...
}

2、继承原始mapper.xml的结果映射   

原始mapper.xml的结果映射


<mapper namespace="com.xxx.dao.mapper.TagMapper">
  <resultMap id="BaseResultMap" type="com.xxx.dao.Tag">
    <!--
      WARNING - @mbg.generated
      This element is automatically generated by MyBatis Generator, do not modify.
    -->
    <id column="id" jdbcType="CHAR" property="id" />
    <result column="tag_name" jdbcType="VARCHAR" property="tagName" />
    <result column="tag_alias" jdbcType="VARCHAR" property="tagAlias" />
  </resultMap>
</mapper>

扩展mapper.xml的结果映射


<mapper namespace="com.xxx.dao.TagExtendMapper">
    <select id="xxxxx" resultMap="com.xxx.dao.mapper.TagMapper.BaseResultMap"> <!-- 这里时原始命名空间加上结果集id -->
    </select>
</mapper>

或者是


<mapper namespace="com.xxx.dao.TagExtendMapper">
   <resultMap id="ExtBaseResultMap" type="com.xxx.dao.Tag" extend="com.xxx.dao.mapper.TagMapper.BaseResultMap">
       ...
  </resultMap>
</mapper>

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

--结束END--

本文标题: mybatis如何实现继承映射

本文链接: https://www.lsjlt.com/news/99.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • mybatis映射文件操作存储过程如何实现
    本篇内容主要讲解“mybatis映射文件操作存储过程如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis映射文件操作存储过程如何实现”吧!先随便创建一个存储过程DELIMITER...
    562
    2023-10-01
  • mybatis映射怎么实现
    这篇文章主要介绍“mybatis映射怎么实现”,在日常操作中,相信很多人在mybatis映射怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mybatis映射怎么实现”的疑惑有所帮助!接下来,请跟着小编...
    465
    2023-10-01
  • php如何实现映射
    小编给大家分享一下php如何实现映射,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!映射映射,或者射影,在数学及相关的领域经常等同于函数。基于此,部分映射就相当于部...
    440
    2023-10-01
  • mybatis如何实现一对一关联映射
    小编给大家分享一下mybatis如何实现一对一关联映射,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言在客观世界中,对象很少是孤独存在的,如班级与学生之间的关系...
    241
    2023-10-01
    mybatis
  • (14)Hibernate继承映射
    人们总是在失去时,才了解到事情的本质需求:动物、猫、猴子1、简单继承映射Animal.javapackage com.rk.hibernate.n_inheritance1; public&nb...
    641
    2023-10-01
    hibernate te na
  • JavaScript如何实现继承的
    JavaScript是一种面向对象的语言,而继承是面向对象编程的一个重要特性。在JavaScript中,继承的实现方式有多种,本文将介绍其中较为常见的几种方法。一、原型链继承原型链继承是JavaScript中最基本的一种继承方式,也是最常用...
    823
    2023-10-01
  • 原生Javascript如何实现继承
    这篇文章将为大家详细讲解有关原生Javascript如何实现继承,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言最近在复习javascript的一些基础知识,为开启新的征程做准备。所以开始记录一些自己学...
    471
    2023-10-01
  • javascript是如何实现继承的
    本篇内容介绍了“javascript是如何实现继承的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    443
    2023-10-01
    javascript
  • Java中的继承如何实现
    本篇内容主要讲解“Java中的继承如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中的继承如何实现”吧!一. 继承众所周知,我们Java语言是一种面向对象的编程语言,每当我们提到J...
    328
    2023-10-01
  • mybatis如何实现saveOrUpdate
    目录1. selectKey标签查询2. 主键自增或者累加的,不使用selectKey3. 主键为varchar的使用ON DUPLICATE KEY UPDATE总结1....
    632
    2023-10-01
    mybatis saveOrUpdate mybatis实现saveOrUpdate
  • docker中volumes文件如何实现映射
    小编给大家分享一下docker中volumes文件如何实现映射,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!实现通过docker-compose配置文件volum...
    254
    2023-10-01
  • MyBatis如何自定义映射resultMap
    这篇文章主要讲解了“MyBatis如何自定义映射resultMap”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MyBatis如何自定义映射resultMap”吧!1 准备工作1.1 建表t...
    716
    2023-10-01
  • es6中如何实现继承
    本篇内容介绍了“es6中如何实现继承”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    551
    2023-10-01
    es6
  • VB.NET如何实现多重继承
    小编给大家分享一下VB.NET如何实现多重继承,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!VB.NET多重继承我注意到了一个情况,那就是C#允许多重继承(multiple inheritance),但是在VB.NET里我...
    752
    2023-10-01
  • VB.NET如何实现继承类
    这篇文章主要为大家展示了“VB.NET如何实现继承类”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“VB.NET如何实现继承类”这篇文章吧。VB.NET继承类是一个这样的特征即允许你扩展类,如果你...
    930
    2023-10-01
  • Laravel框架模板继承操作如何实现
    本文小编为大家详细介绍“Laravel框架模板继承操作如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel框架模板继承操作如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。laravel和T...
    730
    2023-10-01
  • myBatis如何实现查询
    这篇文章主要为大家展示了“myBatis如何实现查询”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“myBatis如何实现查询”这篇文章吧。把查询的字段,查询的条...
    178
    2023-10-01
    mybatis
  • Mybatis如何实现InsertOrUpdate功能
    目录实现InsertOrUpdate功能需求实现Mybatis学习笔记:InsertOrUpdate环境前言DaoMapper XML文件行别名主键和唯一索引 实...
    875
    2023-10-01
    Mybatis InsertOrUpdate InsertOrUpdate功能 Mybatis实现InsertOrUpdate
  • MyBatis懒加载如何实现
    这篇文章主要介绍“MyBatis懒加载如何实现”,在日常操作中,相信很多人在MyBatis懒加载如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyBatis懒加载如何实现”的疑惑有所帮助!接下来,请跟...
    324
    2023-10-01
  • Mybatis如何实现SQL存储
    这篇“Mybatis如何实现SQL存储”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mybatis如何实现SQL存储”文章吧...
    332
    2023-10-01
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作