java框架之Mybatis03(一对多)

java框架之Mybatis03(一对一)

》》》》》》》》》

数据库

use Student;
CREATE TABLE grade (
    id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
    gradeName VARCHAR(20)

)


use student;
CREATE TABLE student (
    sno INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
    sname VARCHAR(12) NOT NULL,
    sage INT NOT NULL,
    addressID INT,
    FOREIGN KEY (addressID)
        REFERENCES address (id),
    gradeID INT,
    FOREIGN KEY (gradeID)
        REFERENCES grade (id)

)

》》》》》》》》》

Model

import java.util.List;

public class Grade {
    private int id;
    private String gradeName;
    private List<Student> students;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getGradeName() {
        return gradeName;
    }
    public void setGradeName(String gradeName) {
        this.gradeName = gradeName;
    }
    public List<Student> getStudents() {
        return students;
    }
    public void setStudents(List<Student> students) {
        this.students = students;
    }
    @Override
    public String toString() {
        return "Grade [id=" + id + ", gradeName=" + gradeName + ", students=" + students + "]";
    }
}

》》》》》》》》》

import com.imis.model.Grade;

public interface GradeMapper {
    
    public Grade findByID(int id);
}

》》》》》》》》》

映射配置

StudentMapper.xml

<select id="findByGradeId" resultMap="StudentResult" parameterType="Integer">
         select * from student where gradeID=#{gradeID}
     </select>

 

GradeMapper.java

<?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.imis.mappers.GradeMapper">
     
     <resultMap type="Grade" id="GradeResult">
         <result property="id" column="id"/>
         <result property="gradeName" column="gradeName"/>
         <collection property="students" column="id" select="com.imis.mappers.StudentMapper.findByGradeId"></collection>
     </resultMap>
     
     <select id="findByID" parameterType="Integer" resultMap="GradeResult">
         select * from grade where id=#{id}
     </select>

 </mapper>  

》》》》》》》》》》》

StudentMapper.java

public Student findByGradeId(int gradeID);

》》》》》》》》》》》

测试

import org.apache.ibatis.session.SqlSession;
import org.apache.log4j.Logger;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import com.imis.mappers.GradeMapper;
import com.imis.model.Grade;
import com.imis.util.SqlSessionFactoryUtil;

public class GradeTest {
    private static Logger logger=Logger.getLogger(GradeTest.class);
    private SqlSession sqlSession=null;
    private GradeMapper gradeMapper=null;
    @Before
    public void setUp() throws Exception {
        sqlSession=SqlSessionFactoryUtil.openSession();
        gradeMapper=sqlSession.getMapper(GradeMapper.class);
    }

    @After
    public void tearDown() throws Exception {
        sqlSession.close();
    }

    @Test
    public void testFindGradeWithStudent() {
        logger.info("查询年级(带学生)");
        System.out.println("1");
        Grade grade=gradeMapper.findByID(2);
        System.out.println("2");
        System.out.println(grade);
    }

}

》》》》》

查询学生带年级,同address

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值