一、properties
1、properties配置
用法一:
${username}和${password}被替换成dev_user和F2Fa3!33TYyg
用法二:
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, props);或SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment, props);
2、如果属性在不只一个地方进行了配置,那么 MyBatis 将按照下面的顺序来加载:
(1)在 properties 元素体内指定的属性首先被读取。
(2)然后根据 properties 元素中的 resource 属性读取类路径下属性文件或根据 url 属性指定的路径读取属性文件,并覆盖已读取的同名属性。
(3)最后读取作为方法参数传递的属性,并覆盖已读取的同名属性。
3、为占位符指定一个默认值
添加一个指定的属性来开启这个特性
4、使用三元运算符
二、settings
三、typeAliases
类型别名是为 Java 类型设置一个短的名字。它只和 XML 配置有关,存在的意义仅在于用来减少类完全限定名的冗余。例如:
指定一个包名:
四、typeHandlers
1、无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。
2、你可以重写类型处理器或创建你自己的类型处理器来处理不支持的或非标准的类型。具体做法为:实现 org.apache.ibatis.type.TypeHandler 接口, 或继承一个很便利的类 org.apache.ibatis.type.BaseTypeHandler, 然后可以选择性地将它映射到一个 JDBC 类型。
3、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 为你查找类型处理器:
五、处理枚举类型
六、对象工厂
// ExampleObjectFactory.javapublic class ExampleObjectFactory extends DefaultObjectFactory { public Object create(Class type) { return super.create(type); } public Object create(Class type, ListconstructorArgTypes, List
七、插件
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) { }}
八、配置环境
1、每个数据库对应一个 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);
2、数据源
UNPOOLED
POOLED
JNDI
九、映射器
告诉 MyBatis 到哪里去找映射文件