欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis學(xué)習(xí)教程(五)-實(shí)現(xiàn)關(guān)聯(lián)表查詢方法詳解

 更新時(shí)間:2016年05月24日 12:04:34   作者:孤傲蒼狼  
本文給大家介紹mybatis關(guān)聯(lián)查詢,包括一對(duì)一關(guān)聯(lián)查詢,一對(duì)多關(guān)聯(lián)查詢,代碼簡(jiǎn)單易懂,感興趣的朋友一起學(xué)習(xí)吧

一、一對(duì)一關(guān)聯(lián)

 1.1、提出需求

  根據(jù)班級(jí)id查詢班級(jí)信息(帶老師的信息)

1.2、創(chuàng)建表和數(shù)據(jù)

  創(chuàng)建一張教師表和班級(jí)表,這里我們假設(shè)一個(gè)老師只負(fù)責(zé)教一個(gè)班,那么老師和班級(jí)之間的關(guān)系就是一種一對(duì)一的關(guān)系。

 CREATE TABLE teacher(
  t_id INT PRIMARY KEY AUTO_INCREMENT, 
  t_name VARCHAR()
 );
 CREATE TABLE class(
  c_id INT PRIMARY KEY AUTO_INCREMENT, 
  c_name VARCHAR(), 
  teacher_id INT
 );
 ALTER TABLE class ADD CONSTRAINT fk_teacher_id FOREIGN KEY (teacher_id) REFERENCES teacher(t_id); 
 INSERT INTO teacher(t_name) VALUES('teacher');
 INSERT INTO teacher(t_name) VALUES('teacher');
 INSERT INTO class(c_name, teacher_id) VALUES('class_a', );
 INSERT INTO class(c_name, teacher_id) VALUES('class_b', 2); 

  表之間的關(guān)系如下:

1.3、定義實(shí)體類

  1、Teacher類,Teacher類是teacher表對(duì)應(yīng)的實(shí)體類。

 package me.gacl.domain;
 /**
 * @author gacl
 * 定義teacher表對(duì)應(yīng)的實(shí)體類
 */
 public class Teacher {
  //定義實(shí)體類的屬性,與teacher表中的字段對(duì)應(yīng)
  private int id;   //id===>t_id
  private String name; //name===>t_name
  public int getId() {
   return id;
  }
  public void setId(int id) {
   this.id = id;
  }
  public String getName() {
   return name;
  }
  public void setName(String name) {
   this.name = name;
  }
  @Override
  public String toString() {
   return "Teacher [id=" + id + ", name=" + name + "]";
  }
 } 

  2、Classes類,Classes類是class表對(duì)應(yīng)的實(shí)體類

 package me.gacl.domain;
 /**
 * @author gacl
 * 定義class表對(duì)應(yīng)的實(shí)體類
 */
 public class Classes {
  //定義實(shí)體類的屬性,與class表中的字段對(duì)應(yīng)
  private int id;   //id===>c_id
  private String name; //name===>c_name
  /**
  * class表中有一個(gè)teacher_id字段,所以在Classes類中定義一個(gè)teacher屬性,
  * 用于維護(hù)teacher和class之間的一對(duì)一關(guān)系,通過(guò)這個(gè)teacher屬性就可以知道這個(gè)班級(jí)是由哪個(gè)老師負(fù)責(zé)的
  */
  private Teacher teacher;
  public int getId() {
   return id;
  }
  public void setId(int id) {
   this.id = id;
  }
  public String getName() {
   return name;
  }
  public void setName(String name) {
   this.name = name;
  }
  public Teacher getTeacher() {
   return teacher;
  }
  public void setTeacher(Teacher teacher) {
   this.teacher = teacher;
  }
  @Override
  public String toString() {
   return "Classes [id=" + id + ", name=" + name + ", teacher=" + teacher+ "]";
  }
 } 

1.4、定義sql映射文件classMapper.xml

<?xml version="." encoding="UTF-" ?>
 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper .//EN" "http://mybatis.org/dtd/mybatis--mapper.dtd">
 <!-- 為這個(gè)mapper指定一個(gè)唯一的namespace,namespace的值習(xí)慣上設(shè)置成包名+sql映射文件名,這樣就能夠保證namespace的值是唯一的
 例如namespace="me.gacl.mapping.classMapper"就是me.gacl.mapping(包名)+classMapper(classMapper.xml文件去除后綴)
 -->
 <mapper namespace="me.gacl.mapping.classMapper">
  <!-- 
   根據(jù)班級(jí)id查詢班級(jí)信息(帶老師的信息)
   ##. 聯(lián)表查詢
   SELECT * FROM class c,teacher t WHERE c.teacher_id=t.t_id AND c.c_id=;
   ##. 執(zhí)行兩次查詢
   SELECT * FROM class WHERE c_id=; //teacher_id=
   SELECT * FROM teacher WHERE t_id=;//使用上面得到的teacher_id
  -->
  <!-- 
  方式一:嵌套結(jié)果:使用嵌套結(jié)果映射來(lái)處理重復(fù)的聯(lián)合結(jié)果的子集
    封裝聯(lián)表查詢的數(shù)據(jù)(去除重復(fù)的數(shù)據(jù))
   select * from class c, teacher t where c.teacher_id=t.t_id and c.c_id=
  -->
  <select id="getClass" parameterType="int" resultMap="ClassResultMap">
   select * from class c, teacher t where c.teacher_id=t.t_id and c.c_id=#{id}
  </select>
  <!-- 使用resultMap映射實(shí)體類和字段之間的一一對(duì)應(yīng)關(guān)系 -->
  <resultMap type="me.gacl.domain.Classes" id="ClassResultMap">
   <id property="id" column="c_id"/>
   <result property="name" column="c_name"/>
   <association property="teacher" javaType="me.gacl.domain.Teacher">
    <id property="id" column="t_id"/>
    <result property="name" column="t_name"/>
   </association>
  </resultMap>
  <!-- 
  方式二:嵌套查詢:通過(guò)執(zhí)行另外一個(gè)SQL映射語(yǔ)句來(lái)返回預(yù)期的復(fù)雜類型
   SELECT * FROM class WHERE c_id=;
   SELECT * FROM teacher WHERE t_id= // 是上一個(gè)查詢得到的teacher_id的值
  -->
  <select id="getClass" parameterType="int" resultMap="ClassResultMap">
   select * from class where c_id=#{id}
  </select>
  <!-- 使用resultMap映射實(shí)體類和字段之間的一一對(duì)應(yīng)關(guān)系 -->
  <resultMap type="me.gacl.domain.Classes" id="ClassResultMap">
   <id property="id" column="c_id"/>
   <result property="name" column="c_name"/>
   <association property="teacher" column="teacher_id" select="getTeacher"/>
  </resultMap>
  <select id="getTeacher" parameterType="int" resultType="me.gacl.domain.Teacher">
   SELECT t_id id, t_name name FROM teacher WHERE t_id=#{id}
  </select>
 </mapper> 

  在conf.xml文件中注冊(cè)classMapper.xml

<mappers>
  <!-- 注冊(cè)classMapper.xml文件, 
  classMapper.xml位于me.gacl.mapping這個(gè)包下,所以resource寫(xiě)成me/gacl/mapping/classMapper.xml-->
  <mapper resource="me/gacl/mapping/classMapper.xml"/>
</mappers> 

1.5、編寫(xiě)單元測(cè)試代碼

 package me.gacl.test;
 import me.gacl.domain.Classes;
 import me.gacl.util.MyBatisUtil;
 import org.apache.ibatis.session.SqlSession;
 import org.junit.Test;
 public class Test {
  @Test
  public void testGetClass(){
   SqlSession sqlSession = MyBatisUtil.getSqlSession();
   /**
   * 映射sql的標(biāo)識(shí)字符串,
   * me.gacl.mapping.classMapper是classMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
   * getClass是select標(biāo)簽的id屬性值,通過(guò)select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
   */
   String statement = "me.gacl.mapping.classMapper.getClass";//映射sql的標(biāo)識(shí)字符串
   //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Classes對(duì)象返回
   Classes clazz = sqlSession.selectOne(statement,);//查詢class表中id為的記錄
   //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
   sqlSession.close();
   System.out.println(clazz);//打印結(jié)果:Classes [id=, name=class_a, teacher=Teacher [id=, name=teacher]]
  }
  @Test
  public void testGetClass(){
   SqlSession sqlSession = MyBatisUtil.getSqlSession();
   /**
   * 映射sql的標(biāo)識(shí)字符串,
   * me.gacl.mapping.classMapper是classMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
   * getClass是select標(biāo)簽的id屬性值,通過(guò)select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
   */
   String statement = "me.gacl.mapping.classMapper.getClass";//映射sql的標(biāo)識(shí)字符串
   //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Classes對(duì)象返回
   Classes clazz = sqlSession.selectOne(statement,);//查詢class表中id為的記錄
   //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
   sqlSession.close();
   System.out.println(clazz);//打印結(jié)果:Classes [id=, name=class_a, teacher=Teacher [id=, name=teacher]]
  }
 } 

 1.6、MyBatis一對(duì)一關(guān)聯(lián)查詢總結(jié)

  MyBatis中使用association標(biāo)簽來(lái)解決一對(duì)一的關(guān)聯(lián)查詢,association標(biāo)簽可用的屬性如下:

•property:對(duì)象屬性的名稱

 •javaType:對(duì)象屬性的類型

 •column:所對(duì)應(yīng)的外鍵字段名稱

 •select:使用另一個(gè)查詢封裝的結(jié)果

二、一對(duì)多關(guān)聯(lián)

2.1、提出需求

  根據(jù)classId查詢對(duì)應(yīng)的班級(jí)信息,包括學(xué)生,老師

2.2、創(chuàng)建表和數(shù)據(jù)

  在上面的一對(duì)一關(guān)聯(lián)查詢演示中,我們已經(jīng)創(chuàng)建了班級(jí)表和教師表,因此這里再創(chuàng)建一張學(xué)生表

CREATE TABLE student(
 s_id INT PRIMARY KEY AUTO_INCREMENT, 
 s_name VARCHAR(20), 
 class_id INT
);
INSERT INTO student(s_name, class_id) VALUES('student_A', 1);
INSERT INTO student(s_name, class_id) VALUES('student_B', 1);
INSERT INTO student(s_name, class_id) VALUES('student_C', 1);
INSERT INTO student(s_name, class_id) VALUES('student_D', 2);
INSERT INTO student(s_name, class_id) VALUES('student_E', 2);
INSERT INTO student(s_name, class_id) VALUES('student_F', 2); 

2.3、定義實(shí)體類

  1、Student類

 package me.gacl.domain;
 /**
 * @author gacl
 * 定義student表所對(duì)應(yīng)的實(shí)體類
 */
 public class Student {
  //定義屬性,和student表中的字段對(duì)應(yīng)
  private int id;   //id===>s_id
  private String name; //name===>s_name
  public int getId() {
   return id;
  }
  public void setId(int id) {
   this.id = id;
  }
  public String getName() {
   return name;
  }
  public void setName(String name) {
   this.name = name;
  }
  @Override
  public String toString() {
   return "Student [id=" + id + ", name=" + name + "]";
  }
 } 

  2、修改Classes類,添加一個(gè)List<Student> students屬性,使用一個(gè)List<Student>集合屬性表示班級(jí)擁有的學(xué)生,如下:

 package me.gacl.domain;
 import java.util.List;
 /**
 * @author gacl
 * 定義class表對(duì)應(yīng)的實(shí)體類
 */
 public class Classes {
  //定義實(shí)體類的屬性,與class表中的字段對(duì)應(yīng)
  private int id;   //id===>c_id
  private String name; //name===>c_name
  /**
  * class表中有一個(gè)teacher_id字段,所以在Classes類中定義一個(gè)teacher屬性,
  * 用于維護(hù)teacher和class之間的一對(duì)一關(guān)系,通過(guò)這個(gè)teacher屬性就可以知道這個(gè)班級(jí)是由哪個(gè)老師負(fù)責(zé)的
  */
  private Teacher teacher;
  //使用一個(gè)List<Student>集合屬性表示班級(jí)擁有的學(xué)生
  private List<Student> students;
  public int getId() {
   return id;
  }
  public void setId(int id) {
   this.id = id;
  }
  public String getName() {
   return name;
  }
  public void setName(String name) {
   this.name = name;
  }
  public Teacher getTeacher() {
   return teacher;
  }
  public void setTeacher(Teacher teacher) {
   this.teacher = teacher;
  }
  public List<Student> getStudents() {
   return students;
  }
  public void setStudents(List<Student> students) {
   this.students = students;
  }
  @Override
  public String toString() {
   return "Classes [id=" + id + ", name=" + name + ", teacher=" + teacher
     + ", students=" + students + "]";
  }
 } 

2.4、修改sql映射文件classMapper.xml

  添加如下的SQL映射信息

<!-- 
   根據(jù)classId查詢對(duì)應(yīng)的班級(jí)信息,包括學(xué)生,老師
  -->
  <!-- 
  方式一: 嵌套結(jié)果: 使用嵌套結(jié)果映射來(lái)處理重復(fù)的聯(lián)合結(jié)果的子集
  SELECT * FROM class c, teacher t,student s WHERE c.teacher_id=t.t_id AND c.C_id=s.class_id AND c.c_id=
  -->
  <select id="getClass" parameterType="int" resultMap="ClassResultMap">
   select * from class c, teacher t,student s where c.teacher_id=t.t_id and c.C_id=s.class_id and c.c_id=#{id}
  </select>
  <resultMap type="me.gacl.domain.Classes" id="ClassResultMap">
   <id property="id" column="c_id"/>
   <result property="name" column="c_name"/>
   <association property="teacher" column="teacher_id" javaType="me.gacl.domain.Teacher">
    <id property="id" column="t_id"/>
    <result property="name" column="t_name"/>
   </association>
   <!-- ofType指定students集合中的對(duì)象類型 -->
   <collection property="students" ofType="me.gacl.domain.Student">
    <id property="id" column="s_id"/>
    <result property="name" column="s_name"/>
   </collection>
  </resultMap>
  <!-- 
   方式二:嵌套查詢:通過(guò)執(zhí)行另外一個(gè)SQL映射語(yǔ)句來(lái)返回預(yù)期的復(fù)雜類型
    SELECT * FROM class WHERE c_id=;
    SELECT * FROM teacher WHERE t_id= // 是上一個(gè)查詢得到的teacher_id的值
    SELECT * FROM student WHERE class_id= //是第一個(gè)查詢得到的c_id字段的值
  -->
  <select id="getClass" parameterType="int" resultMap="ClassResultMap">
   select * from class where c_id=#{id}
  </select>
  <resultMap type="me.gacl.domain.Classes" id="ClassResultMap">
   <id property="id" column="c_id"/>
   <result property="name" column="c_name"/>
   <association property="teacher" column="teacher_id" javaType="me.gacl.domain.Teacher" select="getTeacher"></association>
   <collection property="students" ofType="me.gacl.domain.Student" column="c_id" select="getStudent"></collection>
  </resultMap>
  <select id="getTeacher" parameterType="int" resultType="me.gacl.domain.Teacher">
   SELECT t_id id, t_name name FROM teacher WHERE t_id=#{id}
  </select>
  <select id="getStudent" parameterType="int" resultType="me.gacl.domain.Student">
   SELECT s_id id, s_name name FROM student WHERE class_id=#{id}
  </select> 

2.5、編寫(xiě)單元測(cè)試代碼

package me.gacl.test;
 import me.gacl.domain.Classes;
 import me.gacl.util.MyBatisUtil;
 import org.apache.ibatis.session.SqlSession;
 import org.junit.Test;
 public class Test {
  @Test
  public void testGetClass(){
   SqlSession sqlSession = MyBatisUtil.getSqlSession();
   /**
   * 映射sql的標(biāo)識(shí)字符串,
   * me.gacl.mapping.classMapper是classMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
   * getClass是select標(biāo)簽的id屬性值,通過(guò)select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
   */
   String statement = "me.gacl.mapping.classMapper.getClass";//映射sql的標(biāo)識(shí)字符串
   //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Classes對(duì)象返回
   Classes clazz = sqlSession.selectOne(statement,);//查詢class表中id為的記錄
   //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
   sqlSession.close();
   //打印結(jié)果:Classes [id=, name=class_a, teacher=Teacher [id=, name=teacher], students=[Student [id=, name=student_A], Student [id=, name=student_B], Student [id=, name=student_C]]]
   System.out.println(clazz);
  }
  @Test
  public void testGetClass(){
   SqlSession sqlSession = MyBatisUtil.getSqlSession();
   /**
   * 映射sql的標(biāo)識(shí)字符串,
   * me.gacl.mapping.classMapper是classMapper.xml文件中mapper標(biāo)簽的namespace屬性的值,
   * getClass是select標(biāo)簽的id屬性值,通過(guò)select標(biāo)簽的id屬性值就可以找到要執(zhí)行的SQL
   */
   String statement = "me.gacl.mapping.classMapper.getClass";//映射sql的標(biāo)識(shí)字符串
   //執(zhí)行查詢操作,將查詢結(jié)果自動(dòng)封裝成Classes對(duì)象返回
   Classes clazz = sqlSession.selectOne(statement,);//查詢class表中id為的記錄
   //使用SqlSession執(zhí)行完SQL之后需要關(guān)閉SqlSession
   sqlSession.close();
   //打印結(jié)果:Classes [id=, name=class_a, teacher=Teacher [id=, name=teacher], students=[Student [id=, name=student_A], Student [id=, name=student_B], Student [id=, name=student_C]]]
   System.out.println(clazz);
  }
 } 

 2.6、MyBatis一對(duì)多關(guān)聯(lián)查詢總結(jié)

  MyBatis中使用collection標(biāo)簽來(lái)解決一對(duì)多的關(guān)聯(lián)查詢,ofType屬性指定集合中元素的對(duì)象類型。

關(guān)于MyBatis學(xué)習(xí)教程(五)-實(shí)現(xiàn)關(guān)聯(lián)表查詢的相關(guān)內(nèi)容就給大家介紹這么多,希望對(duì)大家有所幫助!

相關(guān)文章

  • 一文深入解析JDBC超時(shí)機(jī)制

    一文深入解析JDBC超時(shí)機(jī)制

    恰當(dāng)?shù)腏DBC超時(shí)設(shè)置能夠有效地減少服務(wù)失效的時(shí)間,下面這篇文章主要給大家介紹了關(guān)于JDBC超時(shí)機(jī)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-10-10
  • SpringBoot集成ShedLock實(shí)現(xiàn)分布式定時(shí)任務(wù)流程詳解

    SpringBoot集成ShedLock實(shí)現(xiàn)分布式定時(shí)任務(wù)流程詳解

    ShedLock是一個(gè)鎖,官方解釋是他永遠(yuǎn)只是一個(gè)鎖,并非是一個(gè)分布式任務(wù)調(diào)度器。一般shedLock被使用的場(chǎng)景是,你有個(gè)任務(wù),你只希望他在單個(gè)節(jié)點(diǎn)執(zhí)行,而不希望他并行執(zhí)行,而且這個(gè)任務(wù)是支持重復(fù)執(zhí)行的
    2023-02-02
  • Spring DevTools的介紹

    Spring DevTools的介紹

    今天小編就為大家分享一篇關(guān)于Spring DevTools的介紹,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn)

    Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn)

    這篇文章主要介紹了Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 深入淺析TomCat Session管理分析

    深入淺析TomCat Session管理分析

    這篇文章主要介紹了深入淺析TomCat Session管理分析,需要的朋友可以參考下
    2015-11-11
  • Struts2實(shí)現(xiàn)CRUD(增 刪 改 查)功能實(shí)例代碼

    Struts2實(shí)現(xiàn)CRUD(增 刪 改 查)功能實(shí)例代碼

    CRUD是Create(創(chuàng)建)、Read(讀?。pdate(更新)和Delete(刪除)的縮寫(xiě),它是普通應(yīng)用程序的縮影。接下來(lái)通過(guò)本文給大家介紹Struts2實(shí)現(xiàn)CRUD(增 刪 改 查)功能實(shí)例代碼,感興趣的朋友一起看看吧
    2016-06-06
  • Java超詳細(xì)講解三大特性之一的封裝

    Java超詳細(xì)講解三大特性之一的封裝

    封裝是一個(gè)非常廣泛的概念,小到一個(gè)屬性的封裝,大到一個(gè)框架或者一個(gè)項(xiàng)目的封裝,下面這篇文章主要給大家介紹了關(guān)于java中封裝的那點(diǎn)事,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • java map轉(zhuǎn)Multipart/form-data類型body實(shí)例

    java map轉(zhuǎn)Multipart/form-data類型body實(shí)例

    這篇文章主要介紹了java map轉(zhuǎn)Multipart/form-data類型body實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • Springboot?格式化LocalDateTime的方法

    Springboot?格式化LocalDateTime的方法

    這篇文章主要介紹了Springboot格式化LocalDateTime的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Java重點(diǎn)梳理類與對(duì)象核心原理

    Java重點(diǎn)梳理類與對(duì)象核心原理

    類(class)和對(duì)象(object)是兩種以計(jì)算機(jī)為載體的計(jì)算機(jī)語(yǔ)言的合稱。對(duì)象是對(duì)客觀事物的抽象,類是對(duì)對(duì)象的抽象。類是一種抽象的數(shù)據(jù)類型
    2022-07-07

最新評(píng)論