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>
    ...
  • 相关阅读:
    Android ANR异常解决方案
    数据结构之斐波那契查找
    数据结构之插值查找
    数据结构之折半查找
    Android Task 任务
    java中“==”号的运用
    php中向前台js中传送一个二维数组
    array_unique和array_flip 实现去重间的区别
    js new Date() 获取时间
    手机端html5触屏事件(touch事件)
  • 原文地址:https://www.cnblogs.com/javage/p/9647610.html
Copyright © 2011-2022 走看看