欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis如何實現(xiàn)繼承映射

 更新時間:2021年08月25日 10:29:56   作者:溫歡  
這篇文章主要介紹了mybatis如何實現(xiàn)繼承映射的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis 繼承映射

ORM框架的優(yōu)勢在于能讓我們利用面向?qū)ο蟮乃季S去操作數(shù)據(jù)庫,hibernate作為重量級的ORM框架對面向?qū)ο蟮闹С趾軓姶?。作為半自動化的mybatis,對面向?qū)ο蟮闹С忠彩呛芡陚涞?。這篇文章就來討論一下如何利用mybatis實現(xiàn)繼承映射。

類圖

有一個機動車父類,它有兩個子類:Car和Bus

關(guān)系模型(t_vehicle)

ORM映射有一個原則:對象模型細(xì)粒度,關(guān)系模型粗粒度。所以我們將所有的車都存儲一張表里(t_vehicle),通過鑒別字段vType來區(qū)分車的類型("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 {
	//車門的數(shù)量
	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接口【只關(guān)注查詢】

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 {
	//根據(jù)id查詢機動車
	Vehicle getVechicleById(String id);
	//根據(jù)名字查詢小汽車
	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>

分析

其中最為關(guān)鍵的就是<discriminator>標(biāo)簽中的內(nèi)容,根據(jù)鑒別字段的值自動映射成對應(yīng)的子類

客戶端測試代碼

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 {
    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table t_tag
     *
     * @mbg.generated
     */
    long countByExample(TagExample example);
    /**
     * This method was generated by MyBatis Generator.
     * This method corresponds to the database table t_tag
     *
     * @mbg.generated
     */
    int deleteByExample(TagExample example);
}

擴展后的dao層接口

public interface TagExtendMapper extends TagMapper {
    ...
}

2、繼承原始mapper.xml的結(jié)果映射   

原始mapper.xml的結(jié)果映射

<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的結(jié)果映射

<mapper namespace="com.xxx.dao.TagExtendMapper">
    <select id="xxxxx" resultMap="com.xxx.dao.mapper.TagMapper.BaseResultMap"> <!-- 這里時原始命名空間加上結(jié)果集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>

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • ThreadPoolExecutor參數(shù)含義及源碼執(zhí)行流程詳解

    ThreadPoolExecutor參數(shù)含義及源碼執(zhí)行流程詳解

    這篇文章主要為大家介紹了ThreadPoolExecutor參數(shù)含義及源碼執(zhí)行流程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 優(yōu)化spring?boot應(yīng)用后6s內(nèi)啟動內(nèi)存減半

    優(yōu)化spring?boot應(yīng)用后6s內(nèi)啟動內(nèi)存減半

    這篇文章主要為大家介紹了優(yōu)化spring?boot后應(yīng)用6s內(nèi)啟動內(nèi)存減半的優(yōu)化示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-02-02
  • 淺談Java中的interface應(yīng)用與面向接口編程

    淺談Java中的interface應(yīng)用與面向接口編程

    這篇文章主要介紹了淺談Java中的interface應(yīng)用與面向接口編程,Java的關(guān)鍵字interface應(yīng)用,一個接口,多個實現(xiàn)類,面向接口編程,把業(yè)務(wù)邏輯線提取出來作為接口,具體的業(yè)務(wù)實現(xiàn)通過該接口的實現(xiàn)類來完成,需要的朋友可以參考下
    2023-10-10
  • 在springboot中使用注解將值注入?yún)?shù)的操作

    在springboot中使用注解將值注入?yún)?shù)的操作

    這篇文章主要介紹了在springboot中使用注解將值注入?yún)?shù)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 一文解決springboot打包成jar文件無法正常運行的問題

    一文解決springboot打包成jar文件無法正常運行的問題

    這篇文章主要介紹了一文解決springboot打包成jar文件無法正常運行的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Maven中dependencyManagement管理項目依賴項

    Maven中dependencyManagement管理項目依賴項

    在開發(fā)?Java?項目時,管理和協(xié)調(diào)依賴項的版本號是一項重要而繁瑣的任務(wù),本文主要介紹了Maven中dependencyManagement管理項目依賴項,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • SpringBoot采用AJAX實現(xiàn)異步發(fā)布帖子詳解

    SpringBoot采用AJAX實現(xiàn)異步發(fā)布帖子詳解

    Ajax是一種web應(yīng)用技術(shù),可以借助客戶端腳本(javascript)與服務(wù)端應(yīng)用進行異步通訊,獲取服務(wù)端數(shù)據(jù)以后,可以進行局部刷新,進而提高數(shù)據(jù)的響應(yīng)和渲染速度。所有的Ajax請求都會基于DOM(HTML元素)事件,通過XHR(XMLHttpRequest)對象實現(xiàn)與服務(wù)端異步通訊局部更新
    2022-08-08
  • 利用Java多線程技術(shù)導(dǎo)入數(shù)據(jù)到Elasticsearch的方法步驟

    利用Java多線程技術(shù)導(dǎo)入數(shù)據(jù)到Elasticsearch的方法步驟

    這篇文章主要介紹了利用Java多線程技術(shù)導(dǎo)入數(shù)據(jù)到Elasticsearch的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • nacos配置在代碼中引用的方法講解

    nacos配置在代碼中引用的方法講解

    這篇文章主要介紹了nacos配置在代碼中如何引用,如果主配置中配置的內(nèi)容和拓展配置的內(nèi)容重復(fù)則按主配置的配置 ,如果拓展配置中的內(nèi)容和另一個拓展配置中的內(nèi)容重復(fù),則按下標(biāo)大的配置作為最終的配置,對nacos配置代碼引用相關(guān)知識感興趣朋友一起看看吧
    2022-12-12
  • java如何實現(xiàn)獲取客戶端ip地址的示例代碼

    java如何實現(xiàn)獲取客戶端ip地址的示例代碼

    本文主要介紹了java如何實現(xiàn)獲取客戶端ip地址,主要包括java獲取客戶端ip地址工具類使用實例、應(yīng)用技巧,文中通過示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下
    2022-04-04

最新評論