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>
    ...
  • 相关阅读:
    shell---telnet shell实现
    设计模式-建造者模式
    关于Http2
    转载Resharper使用
    设计模式-原型模式
    设计模式-代理模式
    设计模式-装饰器模式
    设计模式-简单工厂和策略模式
    C#直接发送打印机命令到打印机及ZPL常用打印命令
    C#打印机操作类
  • 原文地址:https://www.cnblogs.com/javage/p/9647610.html
Copyright © 2011-2022 走看看