Mybatis多表关联查询注解方式动态SQL详细笔记

本文主要是介绍Mybatis多表关联查询注解方式动态SQL详细笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#{}和${}的区别

#{}

是占位符,是采用预编译方式向sql中传递,可以防止sql注入,如果往sql中传值,使用#{}

一般用于向sql中的列传值

${}

是将内容直接拼到sql语句中,一般不用于向sql中传值,一般用于向sql动态传递列名

一般用于向sql动态传递列名 例如: 排序时 order by 后面的列名是可以改变的

										 例如:   select 后面的列名也可以自由选择

resultMap

多张表关联查询时要使用resultMap

 使用resultMap标签对查询结果进行自定义映射type = "Admin" 最终返回的结果类型
--><resultMap id="adminMap" type="Admin"><id column="adminid" property="id"></id><result column="account" property="account"></result></resultMap><select id="findAdmin" resultMap="adminMap">select id adminid,account from admin</select>

(1). resutlMap 的 id 属性是 resutlMap 的唯一标识,本例中定义为

“adminMap”

(2). resutlMap 的 type 属性是映射的 POJO 类型

(3). id 标签映射主键,result 标签映射非主键

(4). property 设置对象属性名称,column 映射查询结果的列名称

多表关联处理

resultMap元素中的association

collection

collection关联元素处理一对多关联

例如: 专业与学生的一对多关联

	部门与员工的一对多关联

专业一方配置多方集合

public class Major {private  int id;private  String name;private  Student student;private List<Student> students;
}

学生多方,在多方配置一方

public class Student {private  int id;private  int num;private  String name;private  String gender;private  Major major;}

使用resultMap组装查询结果

 <resultMap id="majorMap" type="Major"><id column="id" property="id"></id><result column="name" property="name"></result><collection property="students" javaType="list" ofType="Student"><result column="num" property="num"></result><result column="sname" property="name"></result></collection></resultMap><select id="findMajorById"  parameterType="int" resultMap="majorMap">selectm.id,m.name,s.num,s.name snamefrom major m inner join student s on s.majorid = m.id where m.id = #{id}</select><select id="findMajors" resultMap="majorMap">
selectm.id,m.name,s.num,s.name snamefrom major m inner join student s on s.majorid = m.id</select>

其中,查询单个专业对应的学生需要对应id,查询所有专业下的所有学生则不需要对应专业id

resultMap中的collection标签需要进行子类对象的配置

property元素是最终对象属性的名称,javaType则是对应返回的java对象类型,对于list这种对象则需要使用ofType对其内部的对象进行绑定,本例中list内部存储的是Student对象

association

association多在嵌套查询中使用,将一个多表关联查询拆分为多次查询,先查询主表数据,然后查询关联表数据

<!--    嵌套查询  先查询主表(学生表)--><resultMap id="studentMap1" type="Student"><id column="id" property="id"></id><result column="num" property="num"></result><result column="name" property="name"></result><result column="gender" property="gender"></result>
<!--        封装关联数据--><association property="major" javaType="Major" select="findMajorById" column="majorid"></association></resultMap><select id="findStudentById1" resultMap="studentMap1">select id,num,name,gender,majorid from student where id  =#{id}</select><!--    嵌套查询学生关联的专业--><select id="findMajorById" resultType="Major">select name from major where id  = #{majorid}</select>

(1). select:指定关联查询对象的 Mapper Statement ID 为 findMajorByID

(2). column=“majorid”;关联查询时将majorid列的值传入 findMajorByID,并将 findMajorByID 查询的结果映射到Student的Major属性中

(3).collection 和 association 都需要配置 select 和 column 属性,两者配置方法相同

注解方式

@Insert : 插入 sql , 和 xml insert sql 语法完全一样
@Select : 查询 sql, 和 xml select sql 语法完全一样
@Update : 更新 sql, 和 xml update sql 语法完全一样
@Delete : 删除 sql, 和 xml delete sql 语法完全一样
@Param : 入参
@Results : 设置结果集合
@Result : 结果

使用案例

查询所有信息
@Select("select * from t_emp")
@Results(id = "empMap",value = {
@Result(column = "emp_id",property = "empId",id = true), 
@Result(column = "emp_name",property = "empName"), 
@Result(column = "emp_tel",property = "empTel"), 
@Result(column = "emp_education",property = "empEducation"), 
@Result(column = "emp_birthday",property = "empBirthday")
})
List<Employee> getAll();查询单个信息
@Select("select * from t_emp where emp_id=#{empId}")
@ResultMap(value="empMap")
Employee getById(@Param("empId") Integer empId);插入信息
@Insert("insert into t_emp (emp_id, emp_name, emp_tel, " +
" emp_education, emp_birthday, fk_dept_id" +
" )" values (#{empId}, #{empName}, #{empTel}, " +
" #{empEducation}, #{empBirthday}, #{fkDeptId}" +
" )")
int insert(Employee record);删除信息
@Delete("delete from t_emp where emp_id=#{empId}")
int deleteByPrimaryKey(@Param("empId") Integer empId);

动态SQL

MyBatis 的一个强大的特性之一通常是它的动态 SQL 能力

MyBatis 中用于实现动态 SQL 的元素主要有:

If

where

trim

set

choose (when, otherwise)

foreach

if元素

if标签可以对传入的条件进行判断

 <select id="teachers" resultType="com.geroge.mybatispro.model.Teacher">select * from teacherwhere type = 1<if test="num!=null">and num = #{num}</if><if test="name!=null">or name =#{name}</if><if test="gender!=null">and gender = #{gender}</if></select>

通过对if中的test元素进行编写,判断指定条件是否成立

若成立则执行标签内的语句,但是上述语句若是没有type = 1这一段,则会出现条件均不成立,where后没有语句的情况

此时可以使用标签

例如:

<select id="teachers" resultType="com.geroge.mybatispro.model.Teacher">select * from teacher<where><if test="num!=null">and num = #{num}</if><if test="name!=null">or name =#{name}</if><if test="gender!=null">and gender = #{gender}</if></where></select>

元素会进行判断,如果它包含的标签中有返回值的话,它就插入一个’where’

trim元素

where标签用trim也可以表示,当where后紧随AND或者OR的时候,就去除AND或者OR

<select id="teachers" resultType="com.geroge.mybatispro.model.Teacher">select * from teacher<trim prefix="where" prefixOverrides="and|or"><if test="num!=null">and num = #{num}</if><if test="name!=null">or name =#{name}</if><if test="gender!=null">and gender = #{gender}</if></trim></select>

prefix是前缀,可以写where,prefixOverrides覆盖指定内容

Choose元素

 <select id="teachers" resultType="com.geroge.mybatispro.model.Teacher">select * from teacher<trim prefix="where" prefixOverrides="and|or"><choose><when test="name!=null">name = #{name}</when><otherwise>name = '李老师'</otherwise></choose></trim></select>

choose元素内部可以指定when和otherwise

前者是首次判断,后者是在所有判断均没有结果时执行

类似java中的if else语句

set元素

set元素可以去除语句中最后的逗号

例如:

 <update id="updateTeacher" parameterType="teacher">update teacher<set><if test="num!=null">num = #{num},</if><if test="name!=null">name = #{name},</if><if test="gender!=null">gender = #{gender}</if></set>where  id = #{id}</update>

上述语句中前两个if的语句后都存在逗号,若是只执行其中一个的话最后的查询语句中就会多出一个逗号

set元素可以自动去除语句中多余的逗号

此操作也可以通过trim元素实现

 <update id="updateTeacher" parameterType="teacher">update teacher<trim prefix="set" suffixOverrides="," suffix="where"><if test="num!=null">num = #{num},</if><if test="name!=null">name = #{name},</if><if test="gender!=null">gender = #{gender}</if></trim>where  id = #{id}</update>

foreach元素

此元素主要用于构建in条件时,它可以在SQL语句中进行迭代一个集合

foreach元素的属性主要有item,index,collection,open,separator,close

item属性表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示迭代过程中每次迭代到的位置

open表示该语句以什么开始(通畅表示前括号),separator表示每次迭代之间以什么符号作为分隔符

close表示以什么结束(通常为后括号)

在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但在不同的情况下,该属性的值是不一样的

如果传入的是单参数且参数类型是一个List的时候,collection属性值为list

如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array

<select id="findTeacher" resultType="com.george.mybatispro.model.Teacher">
select
<foreach item="col" collection="list" separator=",">${col}</foreach>
from-teacher
</select>

这篇关于Mybatis多表关联查询注解方式动态SQL详细笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110778

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v