ibatis返回一对多的关系的写法

ibatis支持返回一对多关系的实体类

  例如:课程可以有多个讲师

   课程类:

    public class CourseDto {

/** cc_course.courseId 课程ID */
private Integer courseId;

/** cc_course.courseName 课程标题 */
private String courseName;

private String creUserName;

       //讲师信息
private List<Lecturer> lecturer;

讲师类:

    public class Lecturer{

/** 讲师ID */
public int lecturerId;
/** 讲师姓名 */
public String lecturerName;

     public String lecturerType;


map写法:

<resultMap id="courseLecturerMap" type="com.pcitc.learn.cc.model.course.CourseDto">
<result column="courseId"    property="courseId"   jdbcType="INTEGER" />
<result column="courseName"  property="courseName"   jdbcType="VARCHAR" />
<result column="creUserName" property="creUserName"  jdbcType="VARCHAR" />
<collection property="lecturer" column="courseId" ofType="com.pcitc.learn.cc.model.course.Lecturer">
            <id property="id" column="lecturerId" javaType="int" jdbcType="INTEGER"/>
            <result property="lecturerName" column="lecturerName" javaType="string" jdbcType="VARCHAR"/>
            <result property="lecturerType" column="lecturerType" javaType="string" jdbcType="INTEGER"/>
        </collection>  
</resultMap>

<select id="queryCourseLecturerForPage" parameterType="java.util.Map" resultMap="courseLecturerMap">
SELECT
A.courseId,
A.courseName,
A.creUserName,
B.lecturerId,
B.lecturerName,
B.lecturerType
FROM
cc_course A
LEFT JOIN cc_lecturer B
ON A.courseId = B.courseId
</select>


说明:left join 关系时分页查询不可用。不用分页查询,这种写法是可以的。




 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值