国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

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

2019-11-26 13:09:23
字體:
來源:轉載
供稿:網友

先說一下需求:

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

創建表:

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

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

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

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

create table book( bid int primary key auto_increment, bname varchar(20)   );

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

create table category( cid int primary key auto_increment, cname varchar(20));

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

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));

插入測試數據

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包,項目結構 如下圖

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

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(); }}

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

修改后的圖書實體類 如下

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語句,使用連接查詢 查出所有的圖書和圖書類別

select  * from  book b  inner join     middle m  on    b.bid=m.m_bid  inner join    category c  on   m.m_cid=c.cid

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

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

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

<?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>
public interface BookMapper { List<Book> queryAll();}

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

<?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方法測試

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"); } }}

測試結果如下圖

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

完整項目下載:點擊下載

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黄龙县| 武宣县| 两当县| 称多县| 兴隆县| 龙口市| 东安县| 文安县| 江油市| 宜君县| 扶沟县| 和硕县| 沙湾县| 巫溪县| 汾西县| 苍南县| 缙云县| 尖扎县| 黄山市| 乐陵市| 和平县| 阳原县| 津市市| 灵寿县| 藁城市| 肇州县| 临高县| 大足县| 田林县| 凤山县| 宁波市| 滨海县| 罗平县| 南宁市| 玉山县| 商城县| 漳浦县| 华宁县| 荣成市| 越西县| 车致|