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映射有一個原則:對象模型細粒度,關(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>標簽中的內(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)文章
Java業(yè)務(wù)中臺確保數(shù)據(jù)一致性的解決方案
數(shù)據(jù)一致性通常指關(guān)聯(lián)數(shù)據(jù)之間的邏輯關(guān)系是否正確和完整。而數(shù)據(jù)存儲的一致性模型則可以認為是存儲系統(tǒng)和數(shù)據(jù)使用者之間的一種約定。如果使用者遵循這種約定,則可以得到系統(tǒng)所承諾的訪問結(jié)果2021-10-10
Mybatis-Plus同時使用邏輯刪除和唯一索引的問題及解決辦法(報數(shù)據(jù)重復(fù)Duplicate entry的
在開發(fā)中,我們經(jīng)常會有邏輯刪除和唯一索引同時使用的情況,但當(dāng)使用mybatis plus時,如果同時使用邏輯刪除和唯一索引,會報數(shù)據(jù)重復(fù)Duplicate entry的問題,如何解決這個問題呢,小編給大家分享Mybatis-Plus同時使用邏輯刪除和唯一索引的問題及解決辦法,一起看看吧2023-11-11
IntelliJ?IDEA?2022.1.1?沒有CVS的過程分析
這篇文章主要介紹了IntelliJ?IDEA?2022.1.1?沒有CVS的過程解析,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07
應(yīng)用啟動數(shù)據(jù)初始化接口CommandLineRunner和Application詳解
這篇文章主要介紹了應(yīng)用啟動數(shù)據(jù)初始化接口CommandLineRunner和Application詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12

