Mybatis参数传递示例代码
作者:DaleZhang 发布时间:2023-05-20 09:43:08
前言
在实际开发中,大多数情况下都需要对 SQL 传入参数以获得想要的结果集,传入的情况分为两种情况:
1、SQL语句的拼接,比如表名、like 条件等;在 mybatis 中使用 ${} 包裹参数,mybati 直接对其进行字符串替换
2、SQL 中作为条件输入的参数,这种情况下,SQL 允许使用 ? 作为占位符来代替参数,在 mybatis 中使用 #{} 包裹参数,使用占位符有以下几点好处:
mybatis 会对包裹的变量进行转义和类型检查,避免以 SQL 注入的方式攻击数据库
默认情况下,mybatis 采用的是预编译的方式,对于数据库而言 SQL 本身没有变化,变化的是传入的参数,数据库只会编译一次,而不会因为作为条件的参数变化而重新编译,节约了 SQL 执行总时间
对于开发人员而言,能够使用 #{} 传入参数的情况都应该采用这种形式。
传入参数
接口 Mapper 传入参数
在 xml 中写 SQL 的时候注意到 parameterType 参数,刚接触的时候就有疑惑,如果有多个参数该如何指定。原来这是一个可选参数,Mybatis 本身就可以通过 TypeHandler 推断出具体传入语句的参数。
总结通过接口方法传入参数的情况:
参数使用添加@Param注解,或者使用 '-parameters' 编译选项并启用 useActualParamName 选项(默认开启)来编译项目
特别的,如果参数是Javabean,在SQL中引用参数的时候可以直接使用属性访问符,而无需通过 get 方法。eg: #{Javabean.id}
配置文件传入参数
有时候为了将表名或者 schema 可配置化,将变量写到配置文件中,避免未来表名变化造成大的改动。
全局变量
首先如果是作为全局的参数,可以将配置文件中的参数都写入到 Javabean 中,使用的时候通过接口 Mapper 传入即可。在 Spring 中
在 Spring 配置文件中,使用 PropertiesFactoryBean 指定配置文件路径,指定 id
在 Javabean 文件中使用通过 @Value("#{id['name']}") 设置变量,并使用 @Component 注解该Javabean
在接口 Mapper 中传入该 Javabean
applicationContext.xml
<bean id="exampleid" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="locations">
<array>
<value>classpath:<name>.properties</value>
</array>
</property>
</bean>
ExampleProperty.java
@Component("exampleProperty")
public class ExampleProperty {
@Value("#{exampleid['name']}")
public String name;
...
}
引用
@Resource
private ExampleProperty exampleProperty;
只在 mybatis SQL 中引用
如果不是作为全局参数,而只是在 SQL 中使用,则可以通过 mybatis 的配置文件 mybatis-config.xml 引入,这里引入的变量所有 SQL 的 xml 中都可以通过 ${} 的方式引入。
mybatis-config.xml
<properties resource="<name>.properties">
<property name="name" value="exampleName"/>
<property name="id" value="exampleId"/>
...
</properties>
参数加载的顺序如下
首先包裹的参数作为默认值(推荐引入配置文件的同时也设定默认参数)
加载 resource 中指定的配置文件,如果已指定了该参数则覆盖
如果通过接口 Mapper 传入了同名参数,接口 Mapper 传入的参数覆盖原有参数值
另外需要注意的是通过 mybatis-config.xml 设定的参数,在 SQL 中无法直接使用 #{} 的方式引入,而有时候又想要用占位符的方式进行预编译,除了使用接口 Mapper 传入参数外,还可以使用<bind>
bind 元素可以从 OGNL 表达式中创建一个变量并将其绑定到上下文
ExampleSQL.xml
<mapper namespace="**.ExampleMapper">
<select id="" resultType="string">
<bind name="id" value="'${id}'"/>
SELECT * FROM ××.××
WHERE ID = #{id}
...
</select>
</mapper>
来源:https://juejin.im/post/5b546f195188251abf415c0d
猜你喜欢
- 前言如今发短信功能已经成为互联网公司的标配,本篇文章将一步步实现java发送短信考察了许多提供短信服务的三方,几乎所有都需要企业认证才可以使
- 问答小剧场 以下会产生信息丢失的类型转换是( ) A.float a=10;
- 需要的Maven<!--redis--> <dependency&g
- 我本地的springboot版本是2.5.1,后面的分析都是基于这个版本 <parent> &nbs
- 前言:我们每天都在编写Java代码,编译,执行。很多人已经知道Java源代码文件(.java后缀)会被Java编译器编译为字节码文件(.cl
- 这篇文章主要介绍了Java代码块与代码加载顺序原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- 简介有时候会需要在c#特别是WPF环境下调用其他的程序,这类型的程序以命令行为执行环境,这里就说明下如何调用exe并传递参数一般有两种方法一
- 在用java的io流读写文件时,总是被它的各种流能得很混乱,有40多个类,理清啦,过一段时间又混乱啦,决定整理一下!以防再忘Java输入/输
- 本文实例讲述了C#验证给定字符串形式日期是否合法的方法。分享给大家供大家参考。具体分析如下:这段C#代码用于验证日期的有效性,对于用户输入的
- 本文实例讲述了JAVA设计模式之备忘录模式。分享给大家供大家参考,具体如下:备忘录模式:又叫做快照模式,指在不破坏封装性的前提下,获取到一个
- 使用注解来配置Action可以实现零配置,零配置将从基于纯XML的配置转化为基于注解的配置。使用注解,可以在大多数情况下避免使用
- 一、添加插件apply plugin: 'maven-publish'二、添加如下配置//打包源码task sourceJa
- 现实开发中,我们难免遇到跨域问题,以前笔者只知道jsonp这种解决方式,后面听说spring只要加入@CrossOrigin即可解决跨域问题
- import java.util.Arrays;public class HeapSort { publ
- 目录操作创建目录File类中有两个方法可以用来创建文件夹:mkdir( )方法创建一个文件夹,成功则返回true,失败则返回false。失败
- CyclicBarrier 接着讲多线程下的其他组件,第一个要讲的就
- JVM的对dll文件的装载过程操作系统装入JVM是通过jdk中Java.exe来完成,通过下面4步来完成JVM环境.1.创建JVM装载环境和
- 一、什么是Websocket?1.WebSocket是HTML5下一种新的协议(websocket协议本质上是一个基于tcp的协议)2.它实
- 一、事务的基本原理Spring事务的本质其实就是数据库对事务的支持,没有数据库的事务支持,spring是无法提供事务功能的。对于纯JDBC操
- 使用Apache.POI中HSSFWorkbook导出到Excel,具体内容如下所示:1.引入Poi依赖(3.12)依赖如下:<dep