Mybatis中的一对多举例分析

本篇内容介绍了“Mybatis中的一对多举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

     一对多

        (1)类别表不变化,新增加产品表,一个类别下有多个产品

        (2)创建Product实体类

private int id;
private String name;
private float price;
setter,getter,tostring

        (3)修改Category实体类,提供products的集合

private int id;
private String name;
List<Product> products;
setter,getter,tostring

        (4)暂时无需 Product.xml

        (5)修改Category.xml

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

            通过left join关联查询,对Category和Product表进行关联查询。

            与前面的有所区别,这里不是用的resultType, 而是resultMap,通过resultMap把数据取出来放在对应的 对象属性里。

            注: Category的id 字段 和Product的id字段同名,Mybatis不知道谁是谁的,所以需要通过取别名cid,pid来区分。name字段同理。

        (6)在TestOneToMany中

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

“Mybatis中的一对多举例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!