MyBatis 内连接association 左外连接collection
前提条件:
学生表 (多 子表) 年级表(一 主表)
1,第一种情况:先查子表所有
student.sql.xml文件如何配
由于有多表连接,无法把查询结果直接封装成一个实体对象--------> 结果转换规则:自己手动指定
内连接 返回单个association
<?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="cn.bdqn.mybatis.mapper.StudentMapper">
<!-- 把查询结果自动的封装成一个对象 ,哪些列是可以自动对应到属性中,连接的外表没法对应到啊,复杂的结果转换resultType没法处理,需要手动指定-->
<select id="findStudent" resultMap="studentMap">
SELECT
s.id,
s.gradeId,
s.name,
g.name as gradeName
FROM Student s INNER JOIN Grade g ON s.gradeId=g.id
ORDER BY s.id
</select> <!-- 结果转换规则,当查询结果无法直接转换成我们想要的,就需编写转换规则,明确表示结果如何转换
id随便起名,type是你想把结果转换成什么类的对象
根据转换规则,查出来的每一行数据都会自动new一个student对象出来
-->
<resultMap id="studentMap" type="Student" >
<!-- 这个是主键特殊 column是我想生成的列名不区分大小写; property是原本实体类中的属性名 必须得一样-->
<id column="id" property="id"/>
<result column="gradeId" property="gradeId"/>
<result column="name" property="name"/>
<!-- 指定单个关联对象的转换规则
property是student类中的grade属性 后边是哪个类
-->
<association property="grade" javaType="Grade">
<!-- column是student类中的gradeId属性 property是原本属于grade类中叫id -->
<id column="gradeId" property="id"/>
<result column="gradeName" property="name"/>
</association>
</resultMap>
</mapper>
package cn.bdqn.mybatis.test; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import cn.bdqn.mybatis.entity.Student;
import cn.bdqn.mybatis.mapper.StudentMapper;
import cn.bdqn.mybatis.util.MyBatisUtil; public class StudentTest {
//先声明返回值
List<Student> students=null;
SqlSession session=null;
//只写了个方法执行查询语句
@Test
public void TestFindStudent() {
try {
//先拿到sql session
session=MyBatisUtil.getSqlSession();
//通过sqlsession拿到mapper对象
StudentMapper mapper=session.getMapper(StudentMapper.class);
students=mapper.findStudent();
} catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally{
session.close();
}
for (Student student : students) {
System.out.println(student.getId()+"\t"+student.getName()+"\t"+student.getGrade().getName()+"\t"+student.getGradeId());
}
}
}
左外连接 返回集合collection
<?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="cn.bdqn.mybatis.mapper.GradeMapper">
<select id="findGrade" resultMap="gradeMap">
SELECT
g.id,
g.name,
s.id AS stuId,
s.gradeId,
s.name AS stuName
FROM Grade g LEFT JOIN Student s ON g.id=s.gradeId
ORDER BY g.id
</select>
<resultMap id="gradeMap" type="Grade">
<id column="id" property="id"/>
<result column="name" property="name"/>
<!--集合转换规则
property:对应的是grade类中哪儿一列;javaType:返回类型;ofType:表示集合中包含的是Student实体类对象。
notNullColumn:根据这一列来创建学生对象,班级得有学生了我才创建一个学生对象,没有学生就不创建了
根据查询结果中的 gradeId列判断学生对象要加入到这个集合中-->
<collection property="students" javaType="list" ofType="Student" notNullColumn="gradeId">
<id column="stuId" property="id"/>
<result column="gradeId" property="gradeId"/>
<result column="stuName" property="name"/>
</collection> </resultMap>
</mapper>
package cn.bdqn.mybatis.test; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import cn.bdqn.mybatis.entity.Grade;
import cn.bdqn.mybatis.entity.Student;
import cn.bdqn.mybatis.mapper.GradeMapper;
import cn.bdqn.mybatis.mapper.StudentMapper;
import cn.bdqn.mybatis.util.MyBatisUtil; public class GradeTest {
//先声明返回值
List<Grade> grades=null;
SqlSession session=null;
//只写了个方法执行查询语句
@Test
public void TestFindGrade() {
try {
//先拿到sql session
session=MyBatisUtil.getSqlSession();
//通过sqlsession拿到mapper对象
GradeMapper mapper=session.getMapper(GradeMapper.class);
grades=mapper.findGrade(); } catch (Exception e) {
e.printStackTrace();
session.rollback();
}finally{
session.close();
} for (Grade grade : grades) {
System.out.println(grade.getId()+"\t"+grade.getName());
System.out.println("------------------");
for (Student student : grade.getStudents()) {
System.out.println(student.getName());
}
System.out.println();
}
} }
MyBatis 内连接association 左外连接collection的更多相关文章
- mysql的内连接,外连接(左外连接,右外连接)巩固
1:mysql的内连接: 内连接(inner join):显示左表以及右表符合连接条件的记录: select a.goods_id,a.goods_name,b.cate_name from tdb_ ...
- SQL 四种连接:内连接、左外连接、右外连接、全连接--转载
原文:http://zwdsmileface.iteye.com/blog/2191730 个人理解 内连接(INNER JOIN)(典型的连接运算,使用像 = 或 <> ...
- sql的交叉连接,内连接,左外连接,右外连接,全外连接总结
实践是最好的检验,一直都对这几个连接查询出来的结果有什么不同不大理解,然后自己放一块查询比较了一下,用结果来说话~ 先建两张表如下: t1: id name age 1 张三 18 2 李四 25 t ...
- 内连接、左外连接、右外连接、全外连接、交叉连接(CROSS JOIN)-----小知识解决大数据攻略
早就听说了内连接与外连接,以前视图中使用过.这次自考也学习了,只是简单理解,现在深入探究学习(由于上篇博客的出现)与实践: 概念 关键字: 左右连接 数据表的连接有: 1.内连接(自然连接): 只有两 ...
- SQL: 左连接,右连接,内连接,左外连接,右外连接,完全连接
例子: ---------------------- --------------------------- a表 id name b表 id job parent_id 1 张三 ...
- SQL:内连接、左外连接、右外连接、全连接、交叉连接区别
有两个表A和表B.表A结构如下: Aid:int:标识种子,主键,自增ID Aname:varchar 数据情况,即用select * from A出来的记录情况如下图1所示: 图1:A表数据表B结构 ...
- SQL的四种连接(左外连接、右外连接、内连接、全连接)
1.内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 stude ...
- MySQL之表连接-> 内连接,左外连接,右外链接,全连接
1.首先创建student库 create database student; 2. 在数据库中创建boy表 和 girl表, mysql> create table boy( -> bo ...
- SQL Server内连接、左外连接、右外连接、完全连接、交叉lianjie
数据准备: create table T1( A ) not null, B ) not null, C tinyint not null ); create table T2( B ) not nu ...
随机推荐
- 某硕笔试题mysql数据库部分(较为全面)
Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 ...
- linux信号机制 - 用户堆栈和内核堆栈的变化【转】
转自:http://itindex.net/detail/16418-linux-%E4%BF%A1%E5%8F%B7-%E5%A0%86%E6%A0%88 此文只简单分析发送信号给用户程序后,用户堆 ...
- Android常见面试题目
1.Activity 的生命周期 转自:http://kb.cnblogs.com/page/70125/ 多谢楼主分享 首先看一下Android api中所提供的Activity生命周期图(不明白的 ...
- jython语言学习笔记
1.变量可以随便定义,不限制类型,不限制数值.开头空4个空格,使用def定义函数,可以嵌套,可以传参. 2.每个语句结束的时候没有分号.定义类的时候没有括号.在print语句的后面有格式转换时要加上% ...
- win8以上版本离线安装.NET
方法一.C盘自带.NET 3.5,安装系统以后直接安装.NET 3.5. 1.按下:win+x,点击“命令提示符(管理员), 2.输入或复制以下代码(不可漏空格):dism.exe / ...
- 怎么使用 Laravel 的服务容器来优化读写数据库中的 options关键词
其中我们可以最方便地利用的一个特性就是 Laravel 的服务容器了.在这里我不多赘述 Service Container 是个啥,想了解的可以自行搜索.不想了解的就只要大致知道它是个可以 绑定/取出 ...
- Android推送方案分析(MQTT/XMPP/GCM)
本文主旨在于,对目前Android平台上最主流的几种消息推送方案进行分析和对比,比较客观地反映出这些推送方案的优缺点,帮助大家选择最合适的实施方案. 方案1. 使用GCM服务(Google Cloud ...
- 24、jQuery常用AJAX-API/Java调用MySQL / Oracle过程与函数
1)掌握jQuery常用AJAX-API 2)掌握Java调用MySQL / Oracle过程与函数 一)jQuery常用AJAX-API 目的:简化客户端与服务端进行局部刷新的异步通讯 (1)取 ...
- 有关对字符串的处理,需要用到List时的简化写法
这是项目中的需要根据ComputerName来获取IP的一个方法,如果出现多个ComputerName,需要将多个ComputerName的字符串以“:”分开,传进方法中,然后再处理不同的Name,然 ...
- Spring集成memcached的详细介绍
前提条件:工程需要引入jar包java_memcached-release_2.0.1.jar 第一步:添加memcached的配置文件. <bean class="org.sprin ...