一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - MyBatis中多對多關系的映射和查詢

MyBatis中多對多關系的映射和查詢

2020-08-02 12:07hnlictmso Java教程

本文主要介紹了MyBatis中多對多關系的映射和查詢的相關知識。具有很好的參考價值,下面跟著小編一起來看下吧

先說一下需求:

 在頁面上顯示數據庫中的所有圖書,顯示圖書的同時,顯示出該圖書所屬的類別(這里一本書可能同時屬于多個類別)

創建表:

 筆者這里使用中間表連接圖書表和圖書類別表,圖書表中沒有使用外鍵關聯圖書類別表

 而是在中間表中引用了圖書主鍵和類別主鍵

 通過中間表來 表示 圖書 和 圖書類別 的關系

建立圖書表(圖書編號,圖書名字)

?
1
2
3
4
5
create table book
(
 bid int primary key auto_increment,
 bname varchar(20)  
);

建立類別表(類別編號,類別名字)

?
1
2
3
4
5
create table category
(
 cid int primary key auto_increment,
 cname varchar(20)
);

建立中間表(圖書編號,類別編號)

?
1
2
3
4
5
6
7
create table middle
(
 m_bid int,
 m_cid int,
 constraint fk_bid foreign key(m_bid) references book(bid),
 constraint fk_cid foreign key(m_cid) references category(cid)
);

插入測試數據

?
1
2
3
4
5
6
7
8
9
10
11
insert into category values (default,'java');
insert into category values (default,'c++');
insert into category values (default,'mysql');
insert into book values (default,'SQL技術');
insert into book values (default,'SSM+MySQL詳解');
insert into book values (default,'C++和java對比');
insert into middle values (1,3);
insert into middle values (2,1);
insert into middle values (2,3);
insert into middle values (3,2);
insert into middle values (3,1);

插入的數據中,第一本書 有一個類別,第二本書和第三本書都有兩個類別

到現在為止,數據庫的事情就完事了。下面,通過MyBatis-Generator生成實體類、DAO接口、XML映射文件  不會點擊這里

為了方便省事,筆者這里通過Java項目演示,將自動生成的文件 放入新建的Java項目中,導入相關的Jar包,項目結構 如下圖

MyBatis中多對多關系的映射和查詢

現在我們打開生成的 圖書實體類 看一下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class Book {
 private Integer bid;
 private String bname;
 public Integer getBid() {
 return bid;
 }
 public void setBid(Integer bid) {
 this.bid = bid;
 }
 public String getBname() {
 return bname;
 }
 public void setBname(String bname) {
 this.bname = bname == null ? null : bname.trim();
 }
}

只有圖書編號、圖書名字 這兩個屬性,而我們的需求是 得到圖書的同時,得到該圖書所屬的 所有類別, 所以 我們可以考慮 給圖書實體類 添加 一個 圖書類別的集合

修改后的圖書實體類 如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class Book {
 private Integer bid;
 private String bname;
 private List<Category> categories;
 public Integer getBid() {
 return bid;
 }
 public void setBid(Integer bid) {
 this.bid = bid;
 }
 public String getBname() {
 return bname;
 }
 public void setBname(String bname) {
 this.bname = bname == null ? null : bname.trim();
 }
 public List<Category> getCategories() {
 return categories;
 }
 public void setCategories(List<Category> categories) {
 this.categories = categories;
 }
}

下面 我們開始寫SQL語句,使用連接查詢 查出所有的圖書和圖書類別

?
1
2
3
4
5
6
7
8
9
10
11
12
select
 *
from
 book b
  inner join
    middle m
  on
    b.bid=m.m_bid
  inner join
    category c
  on
   m.m_cid=c.cid

執行結果如下 完美的顯示了所有圖書 和 該圖書的類別

MyBatis中多對多關系的映射和查詢

下面 我們就在XML映射文件中動手腳,使得 這些數據 能按我們所期望的 自動填充到 圖書實體類中

這里為突出重點 所以將圖書的映射文件和DAO接口 清空,清空后 如下

?
1
2
3
4
5
6
<?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.mybatis.dao.BookMapper" >
 <select id="queryAll">
 </select>
</mapper>
?
1
2
3
public interface BookMapper {
 List<Book> queryAll();
}

清空后 我們開始編寫,編寫結果如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<?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.mybatis.dao.BookMapper" >
 <resultMap type="com.mybatis.entity.Book" id="bookMap">
 <id property="bid" column="bid" />
 <result property="bname" column="bname" />
 <collection property="categories" ofType="com.mybatis.entity.Category">
 <id property="cid" column="cid" />
 <result property="cname" column="cname" />
 </collection>
 </resultMap>
 <select id="queryAll" resultMap="bookMap">
 select
 *
 from
 book b
 inner join
 middle m
 on
 b.bid=m.m_bid
 inner join
 category c
 on
 m.m_cid=c.cid
 </select>
</mapper>

最后我們 編寫main方法測試

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class MyMain {
 public static void main(String[] args) throws IOException {
 String resource = "mybatis-config.xml";
 Reader reader = Resources.getResourceAsReader(resource);
 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader);
 SqlSession session = factory.openSession();
 BookMapper bookMapper = session.getMapper(BookMapper.class);
 for (Book book : bookMapper.queryAll()) {
 System.out.print("["+book.getBname()+"]");
 for(Category category :book.getCategories()){
 System.out.print(category.getCname()+"\t");
 }
 System.out.println("\n");
 }
 }
}

測試結果如下圖

MyBatis中多對多關系的映射和查詢

成功輸出了 所有圖書 和 對應的圖書類別

完整項目下載:點擊下載

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持服務器之家!

原文鏈接:http://www.cnblogs.com/hnlictmso/p/6363277.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天堂在线观看中文字幕 | 男人操女生 | 日本xxxxx高清免费观看 | 丝瓜秋葵番茄绿巨人在线观看 | 视频一本大道香蕉久在线播放 | 55夜色66夜亚州精品站 | 奇米网在线 | 亚洲区在线 | 国产专区日韩精品欧美色 | 欧美成人精品第一区二区三区 | 国内精品久久久久小说网 | 男人使劲躁女人视频免费 | 四虎在线视频免费观看视频 | 成人福利在线观看 | 成人国产在线视频 | 亚洲欧美国产自拍 | 日韩精品欧美激情国产一区 | 亚洲国产欧美目韩成人综合 | 俄罗斯美女破苞 | 欧美猛男同志video在线 | 久久99亚洲AV无码四区碰碰 | 草草影院免费 | 18hdxxxx中国 | 免费网址在线观看入口推荐 | 禁忌高h | 波多野结衣一区免费作品 | 99热这里只有精 | 四虎精品免费国产成人 | 乌克兰18sex性hd | 国产美女下面流出白浆视频 | 4444kk在线看片 | 国产v在线播放 | 亚洲精品国产国语 | 日本暖暖在线视频 | 精品国语对白精品自拍视 | 久久国产精品福利影集 | 国产精品调教 | 亚州精品视频 | 无码乱人伦一区二区亚洲一 | 亚洲精品久久久久久婷婷 | 国产精品视频一区二区三区不卡 |