Mybatis中的一对多举例分析

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

成都创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、网站制作、资中网络推广、小程序开发、资中网络营销、资中企业策划、资中品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联为所有大学生创业者提供资中建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com

     一对多

        (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 products;
setter,getter,tostring

        (4)暂时无需 Product.xml

        (5)修改Category.xml

    
        
            
            
     
            
            
            
                
                
                
            
        
     
        
        
            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
           
    

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

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

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

        (6)在TestOneToMany中

        List cs = session.selectList("listCategory");
        for (Category c : cs) {
            System.out.println(c);
            List ps = c.getProducts();
            for (Product p : ps) {
                System.out.println("\t"+p);
            }
        }

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


网站栏目:Mybatis中的一对多举例分析
网页链接:http://hbruida.cn/article/pjgoeo.html