Mybatis参数传递

在实际开发中,大多数状况下都须要对 SQL 传入参数以得到想要的结果集,传入的状况分为两种状况:java

  1. SQL语句的拼接,好比表名、like 条件等;在 mybatis 中使用 ${} 包裹参数,mybati 直接对其进行字符串替换
  2. SQL 中做为条件输入的参数,这种状况下,SQL 容许使用 ? 做为占位符来代替参数,在 mybatis 中使用 #{} 包裹参数,使用占位符有如下几点好处:
    • mybatis 会对包裹的变量进行转义和类型检查,避免以 SQL 注入的方式攻击数据库
    • 默认状况下,mybatis 采用的是预编译的方式,对于数据库而言 SQL 自己没有变化,变化的是传入的参数,数据库只会编译一次,而不会由于做为条件的参数变化而从新编译,节约了 SQL 执行总时间

对于开发人员而言,可以使用 #{} 传入参数的状况都应该采用这种形式。spring

传入参数

接口 Mapper 传入参数

在 xml 中写 SQL 的时候注意到 parameterType 参数,刚接触的时候就有疑惑,若是有多个参数该如何指定。原来这是一个可选参数,Mybatis 自己就能够经过 TypeHandler 推断出具体传入语句的参数。数据库

总结经过接口方法传入参数的状况:bash

  • 参数使用添加@Param注解,或者使用 '-parameters' 编译选项并启用 useActualParamName 选项(默认开启)来编译项目
  • 特别的,若是参数是Javabean,在SQL中引用参数的时候能够直接使用属性访问符,而无需经过 get 方法。eg: #{Javabean.id}

配置文件传入参数

有时候为了将表名或者 schema 可配置化,将变量写到配置文件中,避免将来表名变化形成大的改动。mybatis

全局变量

首先若是是做为全局的参数,能够将配置文件中的参数都写入到 Javabean 中,使用的时候经过接口 Mapper 传入便可。在 Spring 中app

  1. 在 Spring 配置文件中,使用 PropertiesFactoryBean 指定配置文件路径,指定 id
  2. 在 Javabean 文件中使用经过 @Value("#{id['name']}") 设置变量,并使用 @Component 注解该Javabean
  3. 在接口 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 中均可以经过 ${} 的方式引入。ui

  • mybatis-config.xml
<properties resource="<name>.properties">
        <property name="name" value="exampleName"/>
        <property name="id" value="exampleId"/>
        ...
    </properties>
复制代码

参数加载的顺序以下spa

  1. 首先包裹的参数做为默认值(推荐引入配置文件的同时也设定默认参数)
  2. 加载 resource 中指定的配置文件,若是已指定了该参数则覆盖
  3. 若是经过接口 Mapper 传入了同名参数,接口 Mapper 传入的参数覆盖原有参数值

另外须要注意的是经过 mybatis-config.xml 设定的参数,在 SQL 中没法直接使用 #{} 的方式引入,而有时候又想要用占位符的方式进行预编译,除了使用接口 Mapper 传入参数外,还可使用<bind>code

bind 元素能够从 OGNL 表达式中建立一个变量并将其绑定到上下文xml

  • ExampleSQL.xml
<mapper namespace="**.ExampleMapper">
        <select id="" resultType="string">
            <bind name="id" value="'${id}'"/>
            SELECT * FROM ××.×× 
            WHERE ID = #{id}
            ...
        </select>
    </mapper>
复制代码
相关文章
相关标签/搜索