设置好的属性可以在整个配置文件中用来替换需要动态配置的属性值。比如:

    1. <property name="driver" value="${driver}"/>
    2. <property name="url" value="${url}"/>
    3. <property name="username" value="${username}"/>
    4. <property name="password" value="${password}"/>

    这个例子中的 username 和 password 将会由 properties 元素中设置的相应值来替换。 driver 和 url 属性将会由 config.properties 文件中对应的值来替换。这样就为配置提供了诸多灵活选择。

    如果一个属性在不只一个地方进行了配置,那么,MyBatis 将按照下面的顺序来加载:

    • 首先读取在 properties 元素体内指定的属性。
    • 然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性。
    • 最后读取作为方法参数传递的属性,并覆盖之前读取过的同名属性。

    因此,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的则是 properties 元素中指定的属性。

    1. <dataSource type="POOLED">
    2. <!-- ... -->
    3. </dataSource>

    这个特性默认是关闭的。要启用这个特性,需要添加一个特定的属性来开启这个特性。例如:

    提示 如果你在属性名中使用了 字符(如:db:username),或者在 SQL 映射中使用了 OGNL 表达式的三元运算符(如: ${tableName != null ? tableName : 'global_constants'}),就需要设置特定的属性来修改分隔属性名和默认值的字符。例如:

    1. <properties resource="org/mybatis/example/config.properties">
    2. <!-- ... -->
    3. </properties>