时间:2021-05-20
前言
在实际开发中,大多数情况下都需要对 SQL 传入参数以获得想要的结果集,传入的情况分为两种情况:
1、SQL语句的拼接,比如表名、like 条件等;在 mybatis 中使用 ${} 包裹参数,mybati 直接对其进行字符串替换
2、SQL 中作为条件输入的参数,这种情况下,SQL 允许使用 ? 作为占位符来代替参数,在 mybatis 中使用 #{} 包裹参数,使用占位符有以下几点好处:
对于开发人员而言,能够使用 #{} 传入参数的情况都应该采用这种形式。
传入参数
接口 Mapper 传入参数
在 xml 中写 SQL 的时候注意到 parameterType 参数,刚接触的时候就有疑惑,如果有多个参数该如何指定。原来这是一个可选参数,Mybatis 本身就可以通过 TypeHandler 推断出具体传入语句的参数。
总结通过接口方法传入参数的情况:
配置文件传入参数
有时候为了将表名或者 schema 可配置化,将变量写到配置文件中,避免未来表名变化造成大的改动。
全局变量
首先如果是作为全局的参数,可以将配置文件中的参数都写入到 Javabean 中,使用的时候通过接口 Mapper 传入即可。在 Spring 中
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>参数加载的顺序如下
另外需要注意的是通过 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>总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
问题描述:参数传递为List时:当传递一个List实例或者数组作为参数对象传给Mybatis。此时,Mybatis会自动将它包装在一个Map中,用名称在作为键。
在使用Mybatis的时候,经常会有各种各样的参数传递,不同类型,不同个数的参数。先上个例子:publicListfindOfficeList(@Param("
1:按值传递是什么指的是在方法调用时,传递的参数是按值的拷贝传递。示例如下:publicclassTempTest{privatevoidtest1(inta)
jQuery传递中文参数乱码,原因是默认的传递方式没有采用UTF-8,所有我们可以在传递参数的时候对参数进行编码,然后再操作,代码如下,红色的代码为传递的参数,
前言现在大多项目都是使用mybatis了,但也有些公司使用hibernate。使用mybatis最大的特性就是sql需要自己写,而写sql就需要传递多个参数。面