【持续更新】Mybatis常用代码汇总

目录

通用

[#{} 和 {}](#{} 和 {})

返回类型

查询

sql处理

in数组处理

if语句

[choose when](#choose when)

[association 一对一关联查询](#association 一对一关联查询)

日期格式


通用

#{} 和 ${}

MyBatis 的xml映射配置文件中,动态传参有#{}和${}两种方式

1)#{}:动态解析 -> 预编译 -> 执行

2)${}:动态解析 -> 编译 -> 执行

1)变量替换后,#{} 对应的变量自动加上单引号 ''

2)变量替换后,${} 对应的变量不会加上单引号 ''

1)#{} 能防止sql 注入

2)${} 不能防止sql 注入

使用方式相同

(1)public User getUser(String username,String password);

<select id="getUser" resultType="com.User">select * from t user where username=#{arg0} and password=#{arg1}>

</select>

(2)使用自定义参数名,前提: 在映射器接口方法的参数前加注解@Param("")

public User getUser(@Param("username") String username,@Param("password") String password);

或 public User getUser(User user);

<select id="getUser" resultType="com.User">select * from t user where username=#{username} and password=#{password} </select>

返回类型

1.实体类: 将查询结果封装为Java对象,通常是自定义的实体类

2.Map: 将查询结果封装为Map对象

3.List: 将查询结果封装为List对象。

4.Array: 将查询结果封装为数组对象

5.ResultMap: 将查询结果封装为ResultMap对象

6.自定义类型外理器:根据自定义类型的类或数据类型外理查询结果,将查询结果封装为自定义类型的对象

7.Void: 不返回任何结果。

8.Cursor: 返回结果集的游标,可以逐行读取结果集

9.InputStream: 返回结果集的二进制流,适合处理较大的结果集

查询

sql处理

in数组处理

<if test="bankids !=null and bankids.size()>0" >

and (t.BANKID IN

<foreach item="item" collection="bankids" open="(" close=")" index="index">

<if test="index != 0">

<choose>

<when test="index % 1000 == 999">) OR t.BANKID IN(</when>

<otherwise>,</otherwise>

</choose>

</if>

#{item}

</foreach>)

</if>

if语句

<if test="startdate !=null">

AND t.TRANDATE &gt;= to_date(#{startdate},'yyyy-MM-dd HH24:mi:ss')

</if>

choose when

<choose>

<when test="index % 1000 == 999">) OR t.FILLINFOSTATE IN(</when>

<otherwise>,</otherwise>

</choose>

association 一对一关联查询

<association property="customer" javaType="Customer"

select="com.xu.mapper.CustomerMapper.selectById"

column="{id:customer_id}">

</association>

日期格式

and t.trandate <![CDATA[>=]]> to_date(#{startDate},'yyyy-MM-dd')

相关推荐
dvjr cloi20 分钟前
Spring Framework 中文官方文档
java·后端·spring
研究点啥好呢20 分钟前
滴滴Go后端开发工程师面试题精选:10道高频考题+答案解析
java·开发语言·golang
ictI CABL31 分钟前
SpringBoot3.3.0集成Knife4j4.5.0实战
java
傻瓜搬砖人36 分钟前
SpringMVC的请求
java·前端·javascript·spring
亚历克斯神37 分钟前
Java 开发者 2026 成长路线图:从初级到架构师
java·spring·微服务
佛系彭哥39 分钟前
用飞算JavaAI做项目:在线图书借阅平台设计与实现
java·飞算javaai炫技赛
nudt_qxx39 分钟前
Ubuntu 24.04/26.04 与 Windows 10/11 双系统时间不同步终极解决方案
windows·stm32·ubuntu
亚历克斯神41 分钟前
Java 代码质量保障:静态分析与代码审查实践
java·spring·微服务
一叶飘零_sweeeet42 分钟前
2026 年 Java 面试必问:Spring AI 核心原理,90% 人答不全
java·面试·spring ai
星河耀银海42 分钟前
JAVA 泛型与通配符:从原理到实战应用
android·java·服务器