一、properties配置java
<properties resource="org/mybatis/example/config.properties"> <property name="username" value="dev_user"/> <property name="password" value="F2Fa3!33TYyg"/> </properties>
用法一:数据库
${username}和${password}被替换成dev_user和F2Fa3!33TYygapache
<dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource>
用法二:mybatis
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, props); 或 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment, props);
二、若是属性在不仅一个地方进行了配置,那么 MyBatis 将按照下面的顺序来加载:app
(1)在 properties 元素体内指定的属性首先被读取。dom
(2)而后根据 properties 元素中的 resource 属性读取类路径下属性文件或根据 url 属性指定的路径读取属性文件,并覆盖已读取的同名属性。ui
(3)最后读取做为方法参数传递的属性,并覆盖已读取的同名属性。this
三、为占位符指定一个默认值url
<dataSource type="POOLED"> <property name="username" value="${username:ut_user}"/> <!-- If 'username' property not present, username become 'ut_user' --> </dataSource>
添加一个指定的属性来开启这个特性插件
<properties resource="org/mybatis/example/config.properties"> <property name="org.apache.ibatis.parsing.PropertyParser.enable-default-value" value="true"/> <!-- Enable this feature --> </properties>
四、使用三元运算符
<properties resource="org/mybatis/example/config.properties"> <property name="org.apache.ibatis.parsing.PropertyParser.default-value-separator" value="?:"/> <!-- Change default value of separator --> </properties> <dataSource type="POOLED"> <property name="username" value="${db:username?:ut_user}"/> </dataSource>
<settings> <setting name="cacheEnabled" value="true"/> <setting name="lazyLoadingEnabled" value="true"/> <setting name="multipleResultSetsEnabled" value="true"/> <setting name="useColumnLabel" value="true"/> <setting name="useGeneratedKeys" value="false"/> <setting name="autoMappingBehavior" value="PARTIAL"/> <setting name="autoMappingUnknownColumnBehavior" value="WARNING"/> <setting name="defaultExecutorType" value="SIMPLE"/> <setting name="defaultStatementTimeout" value="25"/> <setting name="defaultFetchSize" value="100"/> <setting name="safeRowBoundsEnabled" value="false"/> <setting name="mapUnderscoreToCamelCase" value="false"/> <setting name="localCacheScope" value="SESSION"/> <setting name="jdbcTypeForNull" value="OTHER"/> <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/> </settings>
类型别名是为 Java 类型设置一个短的名字。它只和 XML 配置有关,存在的意义仅在于用来减小类彻底限定名的冗余。例如:
<typeAliases> <typeAlias alias="Author" type="domain.blog.Author"/> <typeAlias alias="Blog" type="domain.blog.Blog"/> <typeAlias alias="Comment" type="domain.blog.Comment"/> <typeAlias alias="Post" type="domain.blog.Post"/> <typeAlias alias="Section" type="domain.blog.Section"/> <typeAlias alias="Tag" type="domain.blog.Tag"/> </typeAliases>
指定一个包名:
<typeAliases> <package name="domain.blog"/> </typeAliases>
一、不管是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,仍是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。
二、你能够重写类型处理器或建立你本身的类型处理器来处理不支持的或非标准的类型。具体作法为:实现 org.apache.ibatis.type.TypeHandler 接口, 或继承一个很便利的类 org.apache.ibatis.type.BaseTypeHandler, 而后能够选择性地将它映射到一个 JDBC 类型。
三、MyBatis 不会窥探数据库元信息来决定使用哪一种类型,因此你必须在参数和结果映射中指明那是 VARCHAR 类型的字段, 以使其可以绑定到正确的类型处理器上。
(1)经过类型处理器的泛型,MyBatis 能够得知该类型处理器处理的 Java 类型,不过这种行为能够经过两种方法改变:在类型处理器的配置元素(typeHandler element)上增长一个 javaType 属性(好比:javaType="String");在类型处理器的类上(TypeHandler class)增长一个 @MappedTypes 注解来指定与其关联的 Java 类型列表。 若是在 javaType 属性中也同时指定,则注解方式将被忽略。
(2)能够经过两种方式来指定被关联的 JDBC 类型:
在类型处理器的配置元素上增长一个 jdbcType 属性(好比:jdbcType="VARCHAR"); 在类型处理器的类上(TypeHandler class)增长一个 @MappedJdbcTypes 注解来指定与其关联的 JDBC 类型列表。 若是在 jdbcType 属性中也同时指定,则注解方式将被忽略。
(3)让 MyBatis 为你查找类型处理器:
<typeHandlers> <package name="org.mybatis.example"/> </typeHandlers>
<!-- mybatis-config.xml --> <typeHandlers> <typeHandler handler="org.apache.ibatis.type.EnumOrdinalTypeHandler" javaType="java.math.RoundingMode"/> </typeHandlers>
// ExampleObjectFactory.java public class ExampleObjectFactory extends DefaultObjectFactory { public Object create(Class type) { return super.create(type); } public Object create(Class type, List<Class> constructorArgTypes, List<Object> constructorArgs) { return super.create(type, constructorArgTypes, constructorArgs); } public void setProperties(Properties properties) { super.setProperties(properties); } public <T> boolean isCollection(Class<T> type) { return Collection.class.isAssignableFrom(type); }}
<!-- mybatis-config.xml --> <objectFactory type="org.mybatis.example.ExampleObjectFactory"> <property name="someProperty" value="100"/> </objectFactory>
MyBatis 容许你在已映射语句执行过程当中的某一点进行拦截调用。
// ExamplePlugin.java @Intercepts({@Signature( type= Executor.class, method = "update", args = {MappedStatement.class,Object.class})}) public class ExamplePlugin implements Interceptor { public Object intercept(Invocation invocation) throws Throwable { return invocation.proceed(); } public Object plugin(Object target) { return Plugin.wrap(target, this); } public void setProperties(Properties properties) { } } <!-- mybatis-config.xml --> <plugins> <plugin interceptor="org.mybatis.example.ExamplePlugin"> <property name="someProperty" value="100"/> </plugin> </plugins>
一、每一个数据库对应一个 SqlSessionFactory 实例
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment); SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment, properties); 忽略环境参数: SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader); SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, properties);
二、数据源
UNPOOLED
POOLED
JNDI
告诉 MyBatis 到哪里去找映射文件
<!-- 使用相对于类路径的资源引用 --> <mappers> <mapper resource="org/mybatis/builder/AuthorMapper.xml"/> <mapper resource="org/mybatis/builder/BlogMapper.xml"/> <mapper resource="org/mybatis/builder/PostMapper.xml"/> </mappers> <!-- 使用彻底限定资源定位符(URL) --> <mappers> <mapper url="file:///var/mappers/AuthorMapper.xml"/> <mapper url="file:///var/mappers/BlogMapper.xml"/> <mapper url="file:///var/mappers/PostMapper.xml"/> </mappers> <!-- 使用映射器接口实现类的彻底限定类名 --> <mappers> <mapper class="org.mybatis.builder.AuthorMapper"/> <mapper class="org.mybatis.builder.BlogMapper"/> <mapper class="org.mybatis.builder.PostMapper"/> </mappers> <!-- 将包内的映射器接口实现所有注册为映射器 --> <mappers> <package name="org.mybatis.builder"/> </mappers>