mybatis如何實(shí)現(xiàn)繼承映射
mybatis 繼承映射
ORM框架的優(yōu)勢(shì)在于能讓我們利用面向?qū)ο蟮乃季S去操作數(shù)據(jù)庫(kù),hibernate作為重量級(jí)的ORM框架對(duì)面向?qū)ο蟮闹С趾軓?qiáng)大。作為半自動(dòng)化的mybatis,對(duì)面向?qū)ο蟮闹С忠彩呛芡陚涞?。這篇文章就來(lái)討論一下如何利用mybatis實(shí)現(xiàn)繼承映射。
類(lèi)圖
有一個(gè)機(jī)動(dòng)車(chē)父類(lèi),它有兩個(gè)子類(lèi):Car和Bus
關(guān)系模型(t_vehicle)
ORM映射有一個(gè)原則:對(duì)象模型細(xì)粒度,關(guān)系模型粗粒度。所以我們將所有的車(chē)都存儲(chǔ)一張表里(t_vehicle),通過(guò)鑒別字段vType來(lái)區(qū)分車(chē)的類(lèi)型("c"代表Car,"b"代表Bus)
三個(gè)實(shí)體類(lèi)的代碼
Vehicle
package com.tgb.mybatis.model; public class Vehicle { //主鍵id private String id; //車(chē)的名字 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 { //車(chē)門(mén)的數(shù)量 private int carDoor; //車(chē)的牌子 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 { //公共汽車(chē)的容量 private int capacity; public int getCapacity() { return capacity; } public void setCapacity(int capacity) { this.capacity = capacity; } }
看看對(duì)“車(chē)”進(jìn)行操作的Mapper接口【只關(guān)注查詢(xú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查詢(xún)機(jī)動(dòng)車(chē) Vehicle getVechicleById(String id); //根據(jù)名字查詢(xún)小汽車(chē) 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ù)鑒別字段的值自動(dòng)映射成對(duì)應(yīng)的子類(lèi)
客戶(hù)端測(cè)試代碼
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());
很簡(jiǎn)單的一個(gè)例子,和大家分享一下。
mybatis xml映射文件的繼承問(wèn)題
1、首先dao層mapper.java需要繼承原來(lái)的接口
原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); }
擴(kuò)展后的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>
擴(kuò)展mapper.xml的結(jié)果映射
<mapper namespace="com.xxx.dao.TagExtendMapper"> <select id="xxxxx" resultMap="com.xxx.dao.mapper.TagMapper.BaseResultMap"> <!-- 這里時(shí)原始命名空間加上結(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>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
ThreadPoolExecutor參數(shù)含義及源碼執(zhí)行流程詳解
這篇文章主要為大家介紹了ThreadPoolExecutor參數(shù)含義及源碼執(zhí)行流程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11優(yōu)化spring?boot應(yīng)用后6s內(nèi)啟動(dòng)內(nèi)存減半
這篇文章主要為大家介紹了優(yōu)化spring?boot后應(yīng)用6s內(nèi)啟動(dòng)內(nèi)存減半的優(yōu)化示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-02-02淺談Java中的interface應(yīng)用與面向接口編程
這篇文章主要介紹了淺談Java中的interface應(yīng)用與面向接口編程,Java的關(guān)鍵字interface應(yīng)用,一個(gè)接口,多個(gè)實(shí)現(xiàn)類(lèi),面向接口編程,把業(yè)務(wù)邏輯線(xiàn)提取出來(lái)作為接口,具體的業(yè)務(wù)實(shí)現(xiàn)通過(guò)該接口的實(shí)現(xiàn)類(lèi)來(lái)完成,需要的朋友可以參考下2023-10-10在springboot中使用注解將值注入?yún)?shù)的操作
這篇文章主要介紹了在springboot中使用注解將值注入?yún)?shù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04一文解決springboot打包成jar文件無(wú)法正常運(yùn)行的問(wèn)題
這篇文章主要介紹了一文解決springboot打包成jar文件無(wú)法正常運(yùn)行的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07Maven中dependencyManagement管理項(xiàng)目依賴(lài)項(xiàng)
在開(kāi)發(fā)?Java?項(xiàng)目時(shí),管理和協(xié)調(diào)依賴(lài)項(xiàng)的版本號(hào)是一項(xiàng)重要而繁瑣的任務(wù),本文主要介紹了Maven中dependencyManagement管理項(xiàng)目依賴(lài)項(xiàng),具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01SpringBoot采用AJAX實(shí)現(xiàn)異步發(fā)布帖子詳解
Ajax是一種web應(yīng)用技術(shù),可以借助客戶(hù)端腳本(javascript)與服務(wù)端應(yīng)用進(jìn)行異步通訊,獲取服務(wù)端數(shù)據(jù)以后,可以進(jìn)行局部刷新,進(jìn)而提高數(shù)據(jù)的響應(yīng)和渲染速度。所有的Ajax請(qǐng)求都會(huì)基于DOM(HTML元素)事件,通過(guò)XHR(XMLHttpRequest)對(duì)象實(shí)現(xiàn)與服務(wù)端異步通訊局部更新2022-08-08利用Java多線(xiàn)程技術(shù)導(dǎo)入數(shù)據(jù)到Elasticsearch的方法步驟
這篇文章主要介紹了利用Java多線(xiàn)程技術(shù)導(dǎo)入數(shù)據(jù)到Elasticsearch的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07java如何實(shí)現(xiàn)獲取客戶(hù)端ip地址的示例代碼
本文主要介紹了java如何實(shí)現(xiàn)獲取客戶(hù)端ip地址,主要包括java獲取客戶(hù)端ip地址工具類(lèi)使用實(shí)例、應(yīng)用技巧,文中通過(guò)示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下2022-04-04