步驟1:分類和產品的一對多關係
步驟2:表結構
步驟3:準備數據
步驟4:先運行,看到效果,再學習
步驟5:模仿和排錯
步驟6:效果
步驟7:Product實體類
步驟8:修改Category實體類
步驟9:暫時無需 Product.xml
步驟10:修改Category.xml
步驟11:測試運行TestMybatis html
步驟 1 : 分類和產品的一對多關係java
在本知識點作分類和產品的一對多關係,創建在上Mybatis 入門教程的基礎上進行。 sql
一個分類對應多個產品apache
步驟 2 : 表結構session
分類表不變化,新增長產品表mybatis
use how2java; create table product_( id int NOT NULL AUTO_INCREMENT, name varchar(30) DEFAULT NULL, price float DEFAULT 0, cid int , PRIMARY KEY (id) )AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
步驟 3 : 準備數據app
清空category_ 和 product_ 表
新增2條分類數據,id分別是1,2
新增6條產品數據,分別關聯上述2條分類數據ide
use how2java; delete from category_; INSERT INTO category_ VALUES (1,'category1'); INSERT INTO category_ VALUES (2,'category2'); delete from product_; INSERT INTO product_ VALUES (1,'product a', 88.88, 1); INSERT INTO product_ VALUES (2,'product b', 88.88, 1); INSERT INTO product_ VALUES (3,'product c', 88.88, 1); INSERT INTO product_ VALUES (4,'product x', 88.88, 2); INSERT INTO product_ VALUES (5,'product y', 88.88, 2); INSERT INTO product_ VALUES (6,'product z', 88.88, 2);
步驟 4 : 先運行,看到效果,再學習學習
老規矩,先下載下載區(點擊進入)的可運行項目,配置運行起來,確承認用以後,再學習作了哪些步驟以達到這樣的效果。測試
步驟 5 : 模仿和排錯
在確保可運行項目可以正確無誤地運行以後,再嚴格照着教程的步驟,對代碼模仿一遍。
模仿過程不免代碼有出入,致使沒法獲得指望的運行結果,此時此刻經過比較正確答案 ( 可運行項目 ) 和本身的代碼,來定位問題所在。
採用這種方式,學習有效果,排錯有效率,能夠較爲明顯地提高學習速度,跨過學習路上的各個檻。
推薦使用diffmerge軟件,進行文件夾比較。把你本身作的項目文件夾,和個人可運行項目文件夾進行比較。
這個軟件很牛逼的,能夠知道文件夾裏哪兩個文件不對,而且很明顯地標記出來
這裏提供了綠色安裝和使用教程:diffmerge 下載和使用教程
步驟 6 : 效果
步驟 7 : Product實體類
普通的一個pojo
package com.how2java.pojo; public class Product { private int id; private String name; private float price; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public float getPrice() { return price; } public void setPrice(float price) { this.price = price; } @Override public String toString() { return "Product [id=" + id + ", name=" + name + ", price=" + price + "]"; } }
步驟 8 : 修改Category實體類
修改Category實體類,提供products的集合
package com.how2java.pojo; import java.util.List; public class Category { private int id; private String name; List<Product> products; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Product> getProducts() { return products; } public void setProducts(List<Product> products) { this.products = products; } @Override public String toString() { return "Category [id=" + id + ", name=" + name + "]"; } }
步驟 9 : 暫時無需 Product.xml
本例演示經過分類對產品的一對多,暫時無需 Product.xml
步驟 10 : 修改Category.xml
經過left join關聯查詢,對Category和Product表進行關聯查詢。
與前面學習的有所區別,這裏不是用的resultType, 而是resultMap,經過resultMap把數據取出來放在對應的 對象屬性裏
注: Category的id 字段 和Product的id字段同名,Mybatis不知道誰是誰的,因此須要經過取別名cid,pid來區分。
name字段同理。
<?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.how2java.pojo"> <resultMap type="Category" id="categoryBean"> <id column="cid" property="id" /> <result column="cname" property="name" /> <!-- 一對多的關係 --> <!-- property: 指的是集合屬性的值, ofType:指的是集合中元素的類型 --> <collection property="products" ofType="Product"> <id column="pid" property="id" /> <result column="pname" property="name" /> <result column="price" property="price" /> </collection> </resultMap> <!-- 關聯查詢分類和產品表 --> <select id="listCategory" resultMap="categoryBean"> select c.*, p.*, c.id 'cid', p.id 'pid', c.name 'cname', p.name 'pname' from category_ c left join product_ p on c.id = p.cid </select> </mapper>
步驟 11 : 測試運行TestMybatis
package com.how2java; import java.io.IOException; import java.io.InputStream; import java.util.List; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import com.how2java.pojo.Category; import com.how2java.pojo.Product; public class TestMybatis { public static void main(String[] args) throws IOException { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession session = sqlSessionFactory.openSession(); List<Category> cs = session.selectList("listCategory"); for (Category c : cs) { System.out.println(c); List<Product> ps = c.getProducts(); for (Product p : ps) { System.out.println("\t" + p); } } session.commit(); session.close(); } }
更多內容,點擊瞭解: https://how2j.cn/k/mybatis/mybatis-one-to-many/1089.html