Mybatis系列教材 (四)- 基礎 - 一對多


步驟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

測試運行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

相關文章
相關標籤/搜索