mybatis配置文件模板及常用标签介绍说明

news/2025/1/9 3:12:08/

转自:

mybatis配置文件模板及常用标签介绍说明

下文笔者讲述mybatis中配置文件中常见的标签简介说明及mapper配置文件简介说明,如下所示

mybatis配置文件简介

mybatis.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
​<settings><!-- 打印查询语句 --><setting name="logImpl" value="STDOUT_LOGGING" /></settings><!--配置和数据库链接相关的信息--><!--四大件驱动地址用户名密码--><!--default 默认的环境, 在这个配置文件中 可以创建多个环境,如果有多个的时候需要指定默认值,这个值就是下面环境的id值--><environments default=""><environment id=""><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver" /><property name="url" value="jdbc:mysql:///数据库名?useUnicode=true&characterEncoding=utf8"/><property name="username" value="" /><property name="password" value="" /></dataSource></environment></environments><!-- 注册映射文件 --><mappers><!--第一种--><mapper resource="com/qianfeng/mybatis/mapper/UserMapper.xml"/><!--第二种--><!-- 使用下面的注册方式需要满足以下三点要求:1) 映射文件要与Dao接口在同一个包下2) 映射文件名要与Dao接口的简单类名相同3) 映射文件的<mapper/>标签的namespace属性值为Dao接口的全限定性类名满足以上三个条件,那么这里的class属性值就可以填写Dao接口的全限定性类名--><mapper class="com.qianfeng.mybatis.mapper.OderMapper"/><!--第三种--><!-- 使用下面的注册方式需要满足以下四点要求:1) 映射文件要与Dao接口在同一个包下2) 映射文件名要与Dao接口的简单类名相同3) 映射文件的<mapper/>标签的namespace属性值为Dao接口的全限定性类名4) 使用动态Mapper满足以上四个条件,那么这里的name属性值就可以填写Dao接口所在的包名--><package name="com.qianfeng.mybatis.mapper"/><!--第四种--><!-- 下面的方式可以使映射文件存放到本地文件系统,但此方式不常用 --><mapper url="file:///e:/mapper.xml"/></mappers>
</configuration>

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">
<!--namespace 命名空间
对sql的statement进行分类的,我们调用这里面sql
语句的时候会使用
在进行接口式编程时这里是对应接口的全限定名称
如<mapper namespace="com.qianfeng.mybatis.mapper.UserMapper">
-->
<mapper namespace="">​
</mapper>

select标签

<!-- id 代表当前sql语句的id,我们需要通过这个id来找到这个sql语句parameterType: 代表的是参数的数据类型, mybatis内部帮我们封装了一些类型  比如 int代表的是       java.lang.IntegerresultType: 返回结果的全限定名称,或者是mybatis内置的类型public String com.qianfeng.mybatis.pojo.User.getId()//方法的全限定名称#{} 占位符,相当于我们在使用jdbc的时候的? ,里面写什么呢? 如果是一个参数,并且参数的类型是基本数据类型或者是字符串的时候,可以随便写但是为了方便了解是做什么或者是为了方便知道参数的含义,建议写对应的数据名字-->
​
<!--在进行接口式编程时id必须和接口中对应方法的名字一样parameterType 必须和方法的参数一致resultType必须和方法的返回值一致--><select id="findUserById" parameterType="int" resultType="com.qianfeng.mybatis.pojo.User">SELECT * FROM user WHERE id=#{id}</select>

insert标签

    <!--insert是sql里面最特殊的一个语句,只有两种结果,一个是成功,一个是抛异常,不像update#{username}代表从user对象中获取一个名字叫username的属性(注意不是变量名),属性就是get/set        方法去掉getting/set后首字母小写当参数是一个对象的时候,这里面要通过占位符的方式进行填写参数,参数的名字就是要作为参数值的属性的        属性名--><insert id="insertUser" parameterType="com.qianfeng.mybatis.pojo.User">INSERT INTO tb_user (username,password,email,gender,flag,role,code) VALUES (#           {username},#{password},#{email},#{gender},#{flag},#{role},#{code})</insert>

selectkey标签

    <!--selectKey: 获取主键resultType: 主键值的类型keyProperty: 代表主键的值放入到参数中的哪个属性上面,比如当前期望将主键的值放到我们的user对象的id属性上面order: 代表selectKey对应的sql语句的执行顺序,在下面真正的sql语句执行之前还是之后执行,此处我们需要插入数据之后才能知道结果,所以是afterSELECT LAST_INSERT_ID() 获取最后一次插入的主键,这个方法只能获取当前事物中的最后一次插入主键--><insert id="insertUser1" parameterType="com.qianfeng.mybatis.pojo.User">
​<selectKey resultType="int" keyProperty="id" order="AFTER">
​SELECT LAST_INSERT_ID()</selectKey>
​INSERT INTO user (iusername,password,email,gender,flag,role,code) VALUES (#{username},#{password},#{email},#{gender},#{flag},#{role},#{code})</insert>

动态sql标签

mybatis的动态sql语句是基于OGNL表达式的,可以方便的在sql语句中实现某些逻辑。
mybatis的动态sql标签分为以下几类if标签(简单的条件判断)
where标签(主要用来简化sql语句中的wheret条件判断能够智能处理 and or,不必担心多余导致语法错误)
choose标签(when,otherwize)相当于java中的switch,与jstl中的choose类似
trim标签(对包含的内容加上prefix,或者suffix等,前缀和后缀)
set标签(主要用于更新时)
foreach标签(主要用于mybatis in 语句查询时)

if标签

<select id="findUserLike" resultType="User">SELECT * FROM user WHERE  1 =1 <if test="name != null">AND name like #{name}</if>
</select>
​

where标签

<!--查询数据的时候,会有多个条件但是这些条件会出现可能会有,可能没有的情况select * from xxx where a=xxx and b =xxx and c =xxx不允许出现where 1=1 因为这会导致数据库索引失效<where> 会自动去掉第一个符合条件的and-->
<select id="findUserByMult" resultType="com.qianfeng.mybatis.pojo.User">SELECT  id, username, password, email, gender, flag, role, code from tb_user<where><if test="username!=null and username !=''">and username=#{username}</if><if test="email!=null and email !=''">and email=#{email}</if></where>
</select>

choose标签

<!--当when标签条件成立时就执行,然后跳出,当所有的when标签条件都不成立的时候,执行otherwiseb标签中的内容
when和otherwise条件只有一个会输出
-->
<select id="dynamicChooseTest" parameterType="Blog" resultType="Blog">select * from user where 1 = 1<choose><when test="name != null">and name = #{name}</when><when test="info != null">and info = #{info}</when><otherwise>and owner = "owner1"</otherwise></choose></select>

set标签

<!--set标签主要用于更新操作的时候主要是在包含语句前面输出一个set如果包含语句是以逗号(,)结束的话,会将其忽略如果set包含内容为空的话,会报错使用set可以动态更新修改字段-->
<update id="updateUser_if_set" parameterType="com.qianfeng.mybatis.pojo.User">UPDATE user<set><if test="username!= null and username != '' ">username = #{username},</if><if test="sex!= null and sex!= '' ">sex = #{sex},</if><if test="birthday != null ">birthday = #{birthday},</if></set>WHERE user_id = #{userid};
</update> 

trim标签

trim标签是更加灵活用于去除多余关键字的标签,它可以用来实现where和set的效果主要包括四个属性prefix:在包含内容之前加上某些前缀suffix:在包含内容之后加上某些后缀prefixOverrides:把包含内容首部的某些内容覆盖掉,即忽略suffixOverrides:把包含内容尾部的某些内容覆盖掉,即忽略

trim代替where

<select id="dynamicTrimTest" parameterType="User" resultType="User">select * from user<trim prefix="where" prefixOverrides="and |or"><if test="name != null">name = #{name}</if><if test="info != null">and info = #{info}</if><if test="owner != null">or owner = #{owner}</if></trim></select>

trim代替set

<update id="updateUser_if_trim" parameterType="User">UPDATE user<trim prefix="SET" suffixOverrides=","><if test="username != null and username != '' ">username = #{username},</if><if test="sex != null and sex != '' ">sex = #{sex},</if><if test="birthday != null ">birthday = #{birthday},</if></trim>WHERE user_id = #{user_id}
</update> 

foreach标签

foreach标签主要用于构建in条件中主要包括六个属性
index: 指定一个名字,用于迭代过程中,每次迭代到的位置
collection: 代表要遍历的存放参数的集合
item: 每次遍历后的参数存放的位置
open: 遍历之前添加什么内容
close: 遍历完成之后添加什么
separator: 分隔符 ,每次遍历之后添加分隔符,但是最后一次遍历不添加
collection属性的值必须指定,但是在不同情况下,该属性的值是不一样的

主要有以下三种情况

<!--第一种-->
<!--单参数,且参数类型是一个list的时候 collection属性值为list-->
<select id="dynamicForeachTest" resultType="User">select * from user where id in<foreach collection="list" index="index" item="item" open="(" separator=","close=")">#{item}</foreach></select>
​
<!--第二种-->
<!--单参数,且参数类型是一个array的时候 collection属性值为array-->
<select id="dynamicForeach2Test" resultType="User">select * from user where id in<foreach collection="array" index="index" item="item" open="(" separator=","close=")">#{item}</foreach>
</select> 
​
<!--第三种-->
<!--如果传入的参数是多个的话,我们就需要把它封装成map集合当然单参数也可以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key。-->
​
<select id="dynamicForeach3Test" resultType="User">select * from user where title name "%"#{name}"%" and id in<foreach collection="ids" index="index" item="item" open="("separator="," close=")">#{item}</foreach>
</select>

include标签

    <!--声明一个sql语句,此语句可以被复用 使用方式在使用的地方通过include id= sql id--><sql id="getall">SELECT  id, username, password, email, gender, flag, role, code from user</sql><!--include导入一条已经声明好的sql语句--><select id="findUserByMult1" resultType="User"><include refid="getall"/><where><if test="username!=null and username !=''">and username=#{username}</if><if test="email!=null and email !=''">and email=#{email}</if></where></select>

resultmap标签

    <!--resultMap 返回结果的映射,主要用于,返回的列的name与对象本身不一致,或者是多表关联的时候属性id 当前resultmap的标记type 当前resultmap真正的返回结果类型
​标签id sql中返回的列中主键的列名, column sql语句返回的列名,property代表在最终对象上面的属性名result 普通属性--><resultMap id="orderby" type="Order"><id column="id_" property="id"  javaType="string"></id><result column="money_" property="money"/><result column="status_" property="status"/>   </resultMap>
​<!--将返回结果通过resultmap进行解析处理--><select id="findOrderById1" parameterType="string" resultMap="orderby">select id id_ ,  money money_ , status status_  from tb_order where id =#{id}</select>

association标签(一对一关系)

    <resultMap id="addressresultmap" type="Address"><id column="aid" property="id"></id><result property="detail" column="detail"></result><result property="name" column="name"></result><!--对一的标签property 当前这个一的对象在最终返回结果对象中的属性名javaType 指的是关联对象的类型,不设置javatype的话不会给我们自动创建对象--><association property="user" javaType="User"><id column="id" property="id"></id><result column="username" property="username"></result><result column="password" property="password"></result></association>
​</resultMap>
​
​<select id="findAddressAndUserInfoByAddressId" resultMap="addressresultmap" parameterType="int">SELECT  a.id aid,a.detail , a.name,a.phone,a.level,u.id,u.username,u.password,u.email,u.gender,u.flag,u.role,u.code  from tb_address  a ,tb_user u where a.uid=u.id and a.id=#{id}</select>

collection标签(一对多关系)

<!--
一对多的关系
collection 在user对象中 oders集合的属性名, 也就多的一方在少的一方中的属性名
ofType 集合的泛型
-->
​<resultMap id="userorderresultmap" type="com.qianfeng.mybatis.pojo.User" extends="basemap"><!--<id column="uid" property="id"></id>--><!--<result column="username" property="username"/>--><!--<result column="password" property="password"/>-->
​<collection property="orders" ofType="com.qianfeng.mybatis.pojo.Order"><id column="id" property="id"></id><result  column="money" property="money"/><result column="status" property="status"/></collection></resultMap>
​
​<select id="findUserAndOrderByUserId" resultMap="userorderresultmap">select  u.id uid , u.username, u.password,o.id,o.money,o.status from tb_user u ,tb_order o where  u.id=o.uid and u.id =#{id}
​</select>

http://www.ppmy.cn/news/830.html

相关文章

RSTP与MSTP

RSTP RSTP快速生成树树协议 生成树&#xff1a;为了防止二层网络中存在链路冗余时出现环路STP&#xff1a;生成树协议&#xff0c;802.1D标准定义RSTP&#xff1a;快速生成树协议&#xff0c;802.1w标准定义MSTP&#xff1a;多实例生成树协议&#xff0c;802.1s标准定义 STP…

【Android App】蓝牙的设备配对、音频传输、点对点通信的讲解及实战(附源码和演示 超详细)

需要源码请点赞关注收藏后评论区留言私信~~~ 一、蓝牙设备配对 Android提供了蓝牙模块的管理工具&#xff0c;名叫BluetoothAdapter。下面是BluetoothAdapter类常用的方法说明&#xff1a; getDefaultAdapter&#xff1a;获取默认的蓝牙适配器。 getState&#xff1a;获取蓝…

【示例】如何使用Pytorch堆叠一个神经网络

本文主要从大致步骤上讲述如何从零开始构建一个网络&#xff0c;仅提供一个思路&#xff0c;具体实现以实际情况为准。 一、构建网络 class 网络模型(nn.Module):#----初始化函数----##主要用来构建网络单元&#xff0c;类似于类定义def __init__(self,需要传入的参数列表): …

使用PyQt5界面设计

一、环境搭建 直接pip安装即可&#xff1a; pip install PyQt5 pip install pyqt5-tools 二、Qt Designer设计GUI Qt Designer 是通过拖拽的方式放置控件&#xff0c;并实时查看控件效果进行快速UI设计。最终生成.ui文件&#xff0c;可以通过pyuic5工具转换成.py文件。 打开d…

RabbitMQ中的集群架构介绍

文章目录前言一、普通集群(副本集群)1.架构图二、镜像集群1.架构图前言 在之前我们是以单节点的形式来运行mq。在真正的生产实践中&#xff0c;mq主要用来完成两个应用系统间的通信&#xff0c;如果在某一时刻mq宕机了&#xff0c;会导致系统瘫痪&#xff0c;就是无法进行通信…

操作系统02_进程管理_同步互斥信号量_PV操作_死锁---软考高级系统架构师007

存储管理可以分为固定存储管理和分页存储管理。 现在固定存储管理已经不用也不考,但要知道因为固定存储管理指的是整存整取 也就是把一整个程序,比如说10G的游戏全部都存到内存里 这样的话是非常占用内存的,这个固定存储管理现在已经不用了。 然后这里我们主要看分页存储管: …

全国职业院校技能大赛 - ruijie网络模块 - 样卷三解析

目录 一.说明 二.项目背景 三.项目规划和设计 四.网络项目实施

基于51单片机农业大棚温控系统

资料编号&#xff1a;197 大棚种植温控系统概述&#xff1a; 本文介绍的是一个由单片机构成的温度控制系统&#xff0c;主要用来提供测温的解决方案&#xff0c;同时还能实时监控温度变化趋势&#xff0c;以及报警功能。它利用STC89C52RC单片机&#xff0c;DS18B20&#xff0c…