亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis關(guān)聯(lián)查詢之一對多和多對一XML配置詳解

 更新時間:2020年10月19日 10:33:58   作者:百度搜不到…  
這篇文章主要介紹了Mybatis關(guān)聯(lián)查詢之一對多和多對一XML配置詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

平時在開發(fā)過程中dao、bean和XML文件都是自動生成的,很少寫XML的配置關(guān)系,今天記錄一下mybatis的關(guān)聯(lián)查詢中的多對一和一對多的情況。

首先是有兩張表(學(xué)生表Student和老師Teacher表,注:這里只是為了演示一對多和多對一的情況,請不要杠),為了更易懂,這里只設(shè)置了最簡單的幾個必要字段。表結(jié)構(gòu)如下圖

Student表:

Teacher表:

創(chuàng)建實體bean

 Teacher.java:

import java.util.List;

public class Teacher {

 private Integer id;
 private String name;
 private String className;
 private List<Student> students;

 // get、set方法省略

}

Sfudent.java

public class Student {

 private Integer id;
 private String name;
 private Integer teacherId;
 private String className;
 private Teacher teacher;
 
 // get、set方法省略
} 

下面重點來了:配置Mapper.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.tz.mybatis.dao.studentDao"> 
 
 <!-- ///一對多的第一種寫法/// -->
 <resultMap type="Teacher" id="teacherMap">
  <id column="id" property="id"/>
  <result column="name" property="name"/>
   <collection property="students" ofType="Student" column="id">
    <!-- 這里的column對應(yīng)的是下面查詢的別名,而不是表字段名 -->
  <id column="sid" property="id"/>
    <!-- property對應(yīng)JavaBean中的屬性名 -->
  <result column="sname" property="name"/>
  <result column="className" property="className"/>
  </collection>
 </resultMap>
 
 
 <!-- 查詢所有的老師級各自的所有學(xué)生 -->
 <select id="getTeachers" parameterType="Teacher" resultMap="teacherMap">
 SELECT
 t.id,
 t.NAME,
 t.class_Name,
 s.id AS sid,
 s. NAME AS sname,
 s.class_name as className
 FROM
 teacher t
 LEFT JOIN student s ON t.id = s.teacher_id
 </select>
</mapper>

測試類:

package com.tz.test;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;
import com.tz.mybatis.bean.Student;
import com.tz.mybatis.bean.Teacher;

public class TeacherTest {

 private SqlSessionFactory sqlSessionFactory;
 
 @Before
 public void init() throws IOException {
 String resource = "mybatis-config.xml";
 InputStream inputStream = Resources.getResourceAsStream(resource);
 sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
 }
 
 @Test
 public void getTeachers() {
 SqlSession session = sqlSessionFactory.openSession();
 List<Teacher> list = session.selectList("com.tz.mybatis.dao.studentDao.getTeachers");
 System.out.println(list);
 }
 
}

下面給出第二種寫法:

<!-- //一對多的第二種寫法/ -->
 <resultMap type="Teacher" id="teacherMaps">
 <id column="id" property="id"/>
 <result column="name" property="name"/>
 <result column="class_name" property="className"/>
 <collection property="students" ofType="Student" select="getStudents" column="id">
 </collection>
 </resultMap>
 
 
 <!-- 查詢所有的老師級各自的所有學(xué)生 -->
 <select id="getAllTeacher" parameterType="Teacher" resultMap="teacherMaps">
 SELECT
 t.id,
 t.NAME,
 t.class_name
 FROM
 teacher t
 </select>
 
 <select id="getStudents" parameterType="int" resultType="Student">
 select 
 s.id,
 s. NAME,
 s.class_name as className
 from student s
 where teacher_id = #{id}
 </select>

測試類:

@Test
 public void getTeachers2() {
 SqlSession session = sqlSessionFactory.openSession();
 List<Teacher> list = session.selectList("com.tz.mybatis.dao.studentDao.getAllTeacher");
 System.out.println(list);
 }

查詢學(xué)生信息(多對一):

首先還是配置文件:

<resultMap type="Student" id="studentMap">
 <id column="id" property="id"/>
 <result column="name" property="name"/>
 <result column="class_name" property="className"/>
 <result column="teacher_id" property="teacherId"/>
 <association property="teacher" select="getTeacher" column="teacher_id" javaType="Teacher">
 <!-- 這里要注意的是column對應(yīng)的是student中的外鍵,而且需是表字段名 -->
 </association>
 </resultMap>
 
 
 <select id="getStudent" resultMap="studentMap">
 SELECT
 s.id,
 s.name,
 s.class_name,
 s.teacher_id
 FROM
 student s
 </select>
 
 <select id="getTeacher" resultType="Teacher" parameterType="int">
 SELECT
 t.id,
 t.name,
 t.class_name as className 
 FROM teacher t 
 where id = #{teacher_id}
 </select>

測試類:

@Test
 public void getStudents() {
 SqlSession session = sqlSessionFactory.openSession();
 List<Student> list = session.selectList("com.tz.mybatis.dao.studentDao.getStudent");
 System.out.println(list);
 }

最后:當(dāng)然如果不想配置這么麻煩的信息,可以直接寫一個關(guān)聯(lián)查詢的SQL語句,返回結(jié)果直接由Map接受即可。不過這樣就不太符合面向?qū)ο蟮睦砟盍恕?nbsp;

到此這篇關(guān)于Mybatis關(guān)聯(lián)查詢之一對多和多對一XML配置詳解的文章就介紹到這了,更多相關(guān)Mybatis關(guān)聯(lián)查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入淺析jni中的java接口使用

    深入淺析jni中的java接口使用

    這篇文章主要介紹了jni中的java接口使用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • idea在plugins中搜不到插件的解決方法

    idea在plugins中搜不到插件的解決方法

    本文主要介紹了idea在plugins中搜不到插件的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • SpringBoot熔斷機制之CircuitBreaker詳解

    SpringBoot熔斷機制之CircuitBreaker詳解

    這篇文章主要介紹了SpringBoot熔斷機制之CircuitBreaker詳解,SpringBoot的熔斷機制在微服務(wù)架構(gòu)中扮演著重要角色,其中CircuitBreaker是其核心機制之一,用于防止服務(wù)的異常狀態(tài)影響到整個系統(tǒng)的運作,需要的朋友可以參考下
    2023-10-10
  • MyBatis/mybatis-plus項目打印SQL的方法實現(xiàn)

    MyBatis/mybatis-plus項目打印SQL的方法實現(xiàn)

    SpringBoot項目中,經(jīng)常需要打印SQL語句及其參數(shù),本文就來介紹一下MyBatis/mybatis-plus項目打印SQL的方法實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • java servlet結(jié)合mysql搭建java web開發(fā)環(huán)境

    java servlet結(jié)合mysql搭建java web開發(fā)環(huán)境

    之前寫過一篇 servlet+oracle的文章,但是那是因為公司有可能接那么一個項目,然后我當(dāng)時也比較閑,所以隨便學(xué)了下,那玩意是白去研究了,因為公司后面并沒接到那項目。
    2015-12-12
  • Java圖書管理系統(tǒng)課程設(shè)計

    Java圖書管理系統(tǒng)課程設(shè)計

    這篇文章主要為大家詳細(xì)介紹了Java圖書管理系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • java集合進(jìn)行排序的方式總結(jié)

    java集合進(jìn)行排序的方式總結(jié)

    在本篇文章里小編給大家整理的是一篇關(guān)于java集合進(jìn)行排序的兩種方式總結(jié),有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-08-08
  • Java中字符串去重的特性介紹

    Java中字符串去重的特性介紹

    這篇文章主要介紹了Java中字符串去重的特性,是Java8中引入的一個新特性,至于是否真的用起來順手就見仁見智了...需要的朋友可以參考下
    2015-07-07
  • Mybatis的xml文件時間范圍條件查詢方式

    Mybatis的xml文件時間范圍條件查詢方式

    這篇文章主要介紹了Mybatis的xml文件時間范圍條件查詢方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • spring boot實現(xiàn)驗證碼功能

    spring boot實現(xiàn)驗證碼功能

    Spring Boot是由Pivotal團(tuán)隊提供的全新框架,其設(shè)計目的是用來簡化新Spring應(yīng)用的初始搭建以及開發(fā)過程。這篇文章主要介紹了spring boot實現(xiàn)驗證碼功能,需要的朋友可以參考下
    2018-04-04

最新評論