zoukankan      html  css  js  c++  java
  • mybatis中一对多查询collection关联不执行

     今天遇到的原因是因为下面红底id没有,导致关联查询没有条件(id字段没传),所以一直没有执行。

    <?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.***.abc.dao.CompanyMapper" >
      <resultMap id="BaseResultMap" type="com.***.abc.bean.Company" >
        <id column="id" property="id" jdbcType="BIGINT" />
        <result column="company_name" property="companyName" jdbcType="VARCHAR" />
    //一个公司包含多个员工,根据公司id可以查出一个公司 所有员工,一对多的关系。
    <collection property="empList" fetchType="lazy" ofType="com.***.abc.bean.Emp" column="id"
    javaType="ArrayList" select="com.***.abc.dao.EmpMapper.queryListByCompanyId"/>
    </resultMap>
    //根据id去查询公司
    <select id="getCompany" resultMap="BaseResultMap">
    select id,company_name,empList from company where id=#{id}
    </select> </mapper>

     定义一个员工接口

    public interface EmpMapper  { 
    List
    <Emp> queryListByCompanyId(Long companyId);
    }

    //emp的xml

    <?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.***.abc.dao.EmpMapper">
    
        <select id="queryListByCompanyId" parameterType="long" resultType="com.***.abc.bean.Emp">
            SELECT * FROM emp WHERE f.company=#{id}
        </select>
    </mapper>
    ...
  • 相关阅读:
    Global.asax 文件是什么
    C和C++语言学习总结
    iphone窗口传值
    c语言实现队列
    iphone窗口跳转
    NSStirng、NSArray、 文件 以及枚举(Method小集合)
    服务器接受的链接过多,该怎么处理
    c语言实现单链表
    iphone开发 NSXMLParser解析xml文件
    iphone 切换界面
  • 原文地址:https://www.cnblogs.com/javage/p/9647610.html
Copyright © 2011-2022 走看看