亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序功能的實(shí)現(xiàn)

 更新時(shí)間:2021年01月18日 15:27:09   作者:83年老蒜頭  
這篇文章主要介紹了Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序功能的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

目的: 記錄數(shù)據(jù)庫(kù)表與實(shí)體對(duì)象之間不同的映射關(guān)系如何用mybatis的自定義sql和結(jié)果返回集處理。

1、三種對(duì)象映射關(guān)系

1.1 一對(duì)一

一個(gè)人對(duì)應(yīng)一個(gè)身份證,一位同學(xué)對(duì)應(yīng)一個(gè)班級(jí),每個(gè)房間都有自己的房間號(hào),當(dāng)一個(gè)事物它對(duì)應(yīng)另一個(gè)事物是唯一的,那么它們之間的關(guān)系就是一對(duì)一的。

這里我演示的案例是,一個(gè)學(xué)生有著一位老師

老師基礎(chǔ)信息:

在這里插入圖片描述

學(xué)生詳細(xì)信息:

在這里插入圖片描述

如果說(shuō),我們需要將兩個(gè)表一起查出來(lái),我們可以這么做:

問(wèn)題: 如果對(duì)象的列重復(fù)了,必須要使用到別名

1、先定義實(shí)體結(jié)構(gòu),也就是我們返結(jié)果的實(shí)體類(lèi)

public class Student {
 @TableId
 private int id;
 private String name;
 private int tid;
 @TableField(exist = false)
 private Teacher teacher;
}

Teacher:

public class Teacher {
 @TableId
 private int id;
 private String name;
}

2、 編寫(xiě)xml文件

這里有兩種方式,使用association時(shí)的關(guān)鍵在于告訴mybatis如何加載關(guān)聯(lián)(assocition)。

  • 嵌套查詢(xún):通過(guò)執(zhí)行另外一個(gè) SQL 映射語(yǔ)句來(lái)返回預(yù)期的復(fù)雜類(lèi)型。
  • 嵌套結(jié)果:使用嵌套結(jié)果映射來(lái)處理重復(fù)的聯(lián)合結(jié)果的子集。

第一種: 使用嵌套查詢(xún),也就是使用另一個(gè)sql

// teacherMapper.xml
<?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.lll.mybatisplusdemo.mapper.TeacherMapper">
 <select id="getTeacher" parameterType="int" resultType="teacher">
 select * from teacher where id = #{id};
 </select>
</mapper>

// studentMapper.xml
<?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">

 <select id="getStudent2" parameterType="int" resultMap="getStudentMap2">
 select * from student where id =#{id};
 </select>

 <resultMap id="getStudentMap2" type="student">
 <id column="id" property="id"></id>
 <result column="name" property="name"></result>
 <result column="tid" property="tid"></result>
 <association property="teacher" javaType="Teacher" column="tid" select="com.lll.mybatisplusdemo.mapper.TeacherMapper.getTeacher">
  <id column="id" property="id"></id>
  <result column="name" property="name"></result>
 </association>
 </resultMap>
</mapper>

嵌套查詢(xún)的方式很簡(jiǎn)單,但是對(duì)于大型數(shù)據(jù)集合和列表將不會(huì)表現(xiàn)很好。問(wèn)題就是我們熟知的
“N+1 查詢(xún)問(wèn)題”。概括地講, N+1 查詢(xún)問(wèn)題可以是這樣引起的:

  • 你執(zhí)行了一個(gè)單獨(dú)的 SQL 語(yǔ)句來(lái)獲取結(jié)果列表(就是“+1”)。
  • 對(duì)返回的每條記錄,你執(zhí)行了一個(gè)查詢(xún)語(yǔ)句來(lái)為每個(gè)加載細(xì)節(jié)(就是“N”)。

第二種: 使用嵌套結(jié)果來(lái)映射聯(lián)合查詢(xún)來(lái)的數(shù)據(jù)

<?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.lll.mybatisplusdemo.mapper.StudentMapper">
 <select id="getStudent" parameterType="int" resultMap="getStudentMap">
  SELECT a.*,b.id as cid,b.name as cname FROM `student` as a,teacher as b WHERE a.id =#{id} and a.tid = b.id;
 </select>
 <resultMap id="getStudentMap" type="student">
 <id column="id" property="id"></id>
 <result column="name" property="name"></result>
 <result column="tid" property="tid"></result>
 <association property="teacher" javaType="Teacher">
  <id column="cid" property="id"></id>
  <result column="cname" property="name"></result>
 </association>
 </resultMap>
</mapper>

我們?cè)谙鄳?yīng)的mapper中添加方法接口便可以使用了。

1.2 一對(duì)多

案例:一個(gè)老師有多個(gè)學(xué)生

1、實(shí)體類(lèi)

public class Teacher {
 @TableId
 private int id;
 private String name;
 @TableField(exist = false)
 private List<Student> students;
}

2、編寫(xiě)xml

同樣還是,我們先來(lái)個(gè)嵌套結(jié)果映射

嵌套結(jié)果:

// teacherMapper.xml
	<select id="getStudent" parameterType="int" resultMap="getStudentMap">
 SELECT a.*,b.id as cid,b.name as cname,b.tid
 from teacher as a , student as b
 where b.tid = a.id and a.id =#{id};
 </select>

 <resultMap id="getStudentMap" type="teacher">
 <id column="id" property="id"></id>
 <result column="name" property="name"></result>
 <collection property="students" ofType="Student">
  <id column="cid" property="id"></id>
  <result column="cname" property="name"></result>
  <result column="tid" property="tid" ></result>
 </collection>
 </resultMap>

嵌套查詢(xún):

// teacherMapper.xml
	<select id="getStudent2" parameterType="int" resultMap="getStudentMap2">
 select * from teacher as a where a.id = #{id}

 </select>
 <resultMap id="getStudentMap2" type="teacher">
 <id column="id" property="id"></id>
 <result column="name" property="name"></result>
 <collection property="students" column="id" ofType="Student" select="com.lll.mybatisplusdemo.mapper.StudentMapper.getStudentByTid">
 </collection>
 </resultMap>

	// studentMapper.xml
 <select id="getStudentByTid" parameterType="int" resultType="student">
 select * from student as a where a.tid = #{id}
 </select>

1.3 多對(duì)多

學(xué)生與課程是多對(duì)多的關(guān)系,與上面的一對(duì)多的操作方式是類(lèi)似的

2、自定義sql如何做分頁(yè)

mapper定義方法,方法傳入page參數(shù)

public interface UserMapper{
 IPage<User> selectPageVo(Page<User> page);
}

userMapper.xml文件編寫(xiě)一個(gè)普通的返回結(jié)果是list的方法,mybatis會(huì)自動(dòng)幫你做分頁(yè)

<select id="selectPage" resultType="com.baomidou.cloud.entity.UserVo">
 SELECT * FROM user 
</select>

3、自定義sql如何做排序

結(jié)論:使用order by,記住要使用'$',不能使用'#'

<select id="selectPage" resultType="com.baomidou.cloud.entity.UserVo">
 SELECT * FROM user order by ${sortColumn} ${sortOrder}
</select>

4、自定義sql中的#{}和${}的區(qū)別

1、傳入的參數(shù)在SQL中顯示不同

#傳入的參數(shù)在SQL中顯示為字符串(當(dāng)成一個(gè)字符串),會(huì)對(duì)自動(dòng)傳入的數(shù)據(jù)加一個(gè)雙引號(hào)。

例:使用以下SQL

select id,name,age from student where id =#{id}

當(dāng)我們傳遞的參數(shù)id為 “1” 時(shí),上述 sql 的解析為:

select id,name,age from student where id ="1"

$傳入的參數(shù)在SqL中直接顯示為傳入的值

例:使用以下SQL

select id,name,age from student where id =${id}

當(dāng)我們傳遞的參數(shù)id為 “1” 時(shí),上述 sql 的解析為:

select id,name,age from student where id =1

2、#可以防止SQL注入的風(fēng)險(xiǎn)(語(yǔ)句的拼接);但$無(wú)法防止Sql注入。

3、$方式一般用于傳入數(shù)據(jù)庫(kù)對(duì)象,例如傳入表名。

4、大多數(shù)情況下還是經(jīng)常使用#,一般能用#的就別用$;但有些情況下必須使用$,例:MyBatis排序時(shí)使用order by 動(dòng)態(tài)參數(shù)時(shí)需要注意,用$而不是#。

到此這篇關(guān)于Mybatis自定義SQL的關(guān)系映射、分頁(yè)、排序的文章就介紹到這了,更多相關(guān)Mybatis自定義SQL的關(guān)系映射內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Maven Helper解決Maven插件沖突的方法

    使用Maven Helper解決Maven插件沖突的方法

    這篇文章主要介紹了使用Maven Helper解決Maven插件沖突的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • Java線(xiàn)程死鎖代碼詳解

    Java線(xiàn)程死鎖代碼詳解

    本篇文章主要介紹了Java線(xiàn)程死鎖代碼詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-11-11
  • java 實(shí)現(xiàn)發(fā)短信功能---騰訊云短信

    java 實(shí)現(xiàn)發(fā)短信功能---騰訊云短信

    如今發(fā)短信功能已經(jīng)成為互聯(lián)網(wǎng)公司的標(biāo)配,接下來(lái)通過(guò)本文給大家介紹java 實(shí)現(xiàn)發(fā)短信功能---騰訊云短信 ,需要的朋友可以參考下
    2019-08-08
  • 關(guān)于Java整合RocketMQ實(shí)現(xiàn)生產(chǎn)消費(fèi)詳解

    關(guān)于Java整合RocketMQ實(shí)現(xiàn)生產(chǎn)消費(fèi)詳解

    這篇文章主要介紹了關(guān)于Java整合RocketMQ實(shí)現(xiàn)生產(chǎn)消費(fèi)詳解,RocketMQ作為一款純java、分布式、隊(duì)列模型的開(kāi)源消息中間件,支持事務(wù)消息、順序消息、批量消息、定時(shí)消息、消息回溯等,需要的朋友可以參考下
    2023-05-05
  • Java中鎖的實(shí)現(xiàn)和內(nèi)存語(yǔ)義淺析

    Java中鎖的實(shí)現(xiàn)和內(nèi)存語(yǔ)義淺析

    這篇文章主要給大家介紹了關(guān)于Java中鎖的實(shí)現(xiàn)和內(nèi)存語(yǔ)義的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • Java中幾種常用數(shù)據(jù)庫(kù)連接池的使用

    Java中幾種常用數(shù)據(jù)庫(kù)連接池的使用

    數(shù)據(jù)庫(kù)連接池在編寫(xiě)應(yīng)用服務(wù)是經(jīng)常需要用到的模塊,太過(guò)頻繁的連接數(shù)據(jù)庫(kù)對(duì)服務(wù)性能來(lái)講是一個(gè)瓶頸,使用緩沖池技術(shù)可以來(lái)消除這個(gè)瓶頸,本文就來(lái)介紹Java常見(jiàn)的幾種,感興趣的可以了解一下
    2021-05-05
  • Java實(shí)現(xiàn)單鏈表基礎(chǔ)操作

    Java實(shí)現(xiàn)單鏈表基礎(chǔ)操作

    大家好,本篇文章主要講的是Java實(shí)現(xiàn)單鏈表基礎(chǔ)操作,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話(huà)記得收藏一下
    2022-02-02
  • Spring Security角色繼承實(shí)現(xiàn)過(guò)程解析

    Spring Security角色繼承實(shí)現(xiàn)過(guò)程解析

    這篇文章主要介紹了Spring Security角色繼承實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Mybatis的核心配置文件使用方法

    Mybatis的核心配置文件使用方法

    Mybatis的核心配置文件有兩個(gè),一個(gè)是全局配置文件,它包含了會(huì)深深影響Mybatis行為的設(shè)置和屬性信息;一個(gè)是映射文件,它很簡(jiǎn)單,讓用戶(hù)能更專(zhuān)注于SQL代碼,本文主要介紹了Mybatis的核心配置文件使用方法,感興趣的可以了解一下
    2023-11-11
  • Spring Boot集成教程之異步調(diào)用Async

    Spring Boot集成教程之異步調(diào)用Async

    在項(xiàng)目中,當(dāng)訪(fǎng)問(wèn)其他人的接口較慢或者做耗時(shí)任務(wù)時(shí),不想程序一直卡在耗時(shí)任務(wù)上,想程序能夠并行執(zhí)行,我們可以使用多線(xiàn)程來(lái)并行的處理任務(wù),也可以使用spring提供的異步處理方式@Async。需要的朋友們下面來(lái)一起看看吧。
    2018-03-03

最新評(píng)論