Mybatis参数传递示例代码
前言
在实际开发中,大多数情况下都需要对 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>
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
推荐阅读
-
Mybatis参数传递示例代码
-
JS 参数传递的实际应用代码分析_javascript技巧
-
put your head on my shoulder PHP页面间传递参数实例代码
-
mybatis利用association或collection传递多参数子查询
-
C#中static void Main(string[] args) 参数的示例代码详解
-
C# WebApi Get请求方式传递实体参数的方法示例
-
JS 参数传递的实际应用代码分析_javascript技巧
-
JS与PHP向函数传递可变参数的区别实例代码
-
如何通过优雅的代码逻辑方式,使得通过get method访问的地址在传递的参数不正确的时候避免出现额外的错误?
-
在Python中如何传递任意数量的实参的示例代码