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>
    ...
  • 相关阅读:
    linux命令大全
    IP协议
    TCP、IP、ARP协议之间的工作关系
    程序出现问题后
    HTTP(超文本传输协议)
    多线程
    syslog.conf文件
    logger命令
    gdb
    二、数据的存储结构
  • 原文地址:https://www.cnblogs.com/javage/p/9647610.html
Copyright © 2011-2022 走看看