在定义sqlSessionFactory时需要指定MyBatis主配置文件:
Xml代码
1
2
3
4
|
< property name = "configLocation" value = "classpath:mybatis-config.xml" />
< property name = "dataSource" ref = "dataSource" />
</ bean >
|
MyBatis配置文件中大标签configuration下子标签包括:
configuration
|--- properties
|--- settings
|--- typeAliases
|--- typeHandlers
|--- objectFactory
|--- plugins
|--- environments
|--- |--- environment
|--- |--- |--- transactionManager
|--- |--- |__ dataSource
|__ mappers
properties属性
properties和java的.properties的配置文件有关。配置properties的resource指定.properties的路径,然后再在properties标签下配置property的name和value,则可以替换.properties文件中相应属性值。
Xml代码
1
2
3
4
5
6
7
|
<!-- 属性替换 -->
< properties resource = "mysql.properties" >
< property name = "jdbc.driverClassName" value = "com.mysql.jdbc.Driver" />
< property name = "jdbc.url" value = "jdbc:mysql://localhost:3306/student_manager" />
< property name = "username" value = "root" />
< property name = "password" value = "limingnihao" />
</ properties >
|
settings设置
这是MyBatis 修改操作运行过程细节的重要的步骤。下方这个表格描述了这些设置项、含义和默认值。
例如:
Xml代码
1
2
3
4
5
6
7
8
9
|
< 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 = "enhancementEnabled" value = "false" />
< setting name = "defaultExecutorType" value = "SIMPLE" />
</ settings >
|
typeAliases类型别名
类型别名是Java 类型的简称。
它仅仅只是关联到XML 配置,简写冗长的JAVA 类名。例如:
Xml代码
1
2
3
4
5
|
< typeAliases >
< typeAlias alias = "UserEntity" type = "com.manager.data.model.UserEntity" />
< typeAlias alias = "StudentEntity" type = "com.manager.data.model.StudentEntity" />
< typeAlias alias = "ClassEntity" type = "com.manager.data.model.ClassEntity" />
</ typeAliases >
|
使用这个配置,“StudentEntity”就能在任何地方代替“com.manager.data.model.StudentEntity”被使用。
对于普通的Java类型,有许多内建的类型别名。它们都是大小写不敏感的,由于重载的名字,要注意原生类型的特殊处理。
typeHandlers类型句柄
无论是MyBatis在预处理语句中设置一个参数,还是从结果集中取出一个值时,类型处理器被用来将获取的值以合适的方式转换成Java类型。下面这个表格描述了默认的类型处理器。
你可以重写类型处理器或创建你自己的类型处理器来处理不支持的或非标准的类型。要这样做的话,简单实现TypeHandler接口(org.mybatis.type),然后映射新的类型处理器类到Java类型,还有可选的一个JDBC类型。然后再typeHandlers中添加这个类型处理器。
新定义的类型处理器将会覆盖已经存在的处理Java的String类型属性和VARCHAR参数及结果的类型处理器。要注意MyBatis不会审视数据库元信息来决定使用哪种类型,所以你必须在参数和结果映射中指定那是VARCHAR类型的字段,来绑定到正确的类型处理器上。这是因为MyBatis直到语句被执行都不知道数据类型的这个现实导致的。
Java代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
public class LimingStringTypeHandler implements TypeHandler {
@Override
public void setParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {
System.out.println( "setParameter - parameter: " + ((String) parameter) + ", jdbcType: " + jdbcType.TYPE_CODE);
ps.setString(i, ((String) parameter));
}
@Override
public Object getResult(ResultSet rs, String columnName) throws SQLException {
System.out.println( "getResult - columnName: " + columnName);
return rs.getString(columnName);
}
@Override
public Object getResult(CallableStatement cs, int columnIndex) throws SQLException {
System.out.println( "getResult - columnIndex: " + columnIndex);
return cs.getString(columnIndex);
}
}
|
在配置文件的typeHandlers中添加typeHandler标签。
Xml代码
1
2
3
|
< typeHandlers >
< typeHandler javaType = "String" jdbcType = "VARCHAR" handler = "liming.student.manager.type.LimingStringTypeHandler" />
</ typeHandlers >
|
ObjectFactory对象工厂
每次MyBatis 为结果对象创建一个新实例,都会用到ObjectFactory。默认的ObjectFactory 与使用目标类的构造函数创建一个实例毫无区别,如果有已经映射的参数,那也可能使用带参数的构造函数。
如果你重写ObjectFactory 的默认操作,你可以通过继承org.apache.ibatis.reflection.factory.DefaultObjectFactory创建一下你自己的。
ObjectFactory接口很简单。它包含两个创建用的方法,一个是处理默认构造方法的,另外一个是处理带参数构造方法的。最终,setProperties方法可以被用来配置ObjectFactory。在初始化你的ObjectFactory实例后,objectFactory元素体中定义的属性会被传递给setProperties方法。
Java代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
public class LimingObjectFactory extends DefaultObjectFactory {
private static final long serialVersionUID = -399284318168302833L;
@Override
public Object create(Class type) {
return super .create(type);
}
@Override
public Object create(Class type, List<Class> constructorArgTypes, List<Object> constructorArgs) {
System.out.println( "create - type: " + type.toString());
return super .create(type, constructorArgTypes, constructorArgs);
}
@Override
public void setProperties(Properties properties) {
System.out.println( "setProperties - properties: " + properties.toString() + ", someProperty: " + properties.getProperty( "someProperty" ));
super .setProperties(properties);
}
}
|
配置文件中添加objectFactory标签
Xml代码
1
2
3
|
< objectFactory type = "liming.student.manager.configuration.LimingObjectFactory" >
< property name = "someProperty" value = "100" />
</ objectFactory >
|
4.6 plugins插件
MyBatis允许你在某一点拦截已映射语句执行的调用。默认情况下,MyBatis允许使用插件来拦截方法调用:
Executor(update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)
ParameterHandler(getParameterObject, setParameters)
ResultSetHandler(handleResultSets, handleOutputParameters)
StatementHandler(prepare, parameterize, batch, update, query)
这些类中方法的详情可以通过查看每个方法的签名来发现,而且它们的源代码在MyBatis的发行包中有。你应该理解你覆盖方法的行为,假设你所做的要比监视调用要多。如果你尝试修改或覆盖一个给定的方法,你可能会打破MyBatis的核心。这是低层次的类和方法,要谨慎使用插件。
使用插件是它们提供的非常简单的力量。简单实现拦截器接口,要确定你想拦截的指定签名。
environments环境
MyBatis 可以配置多个环境。这可以帮助你SQL 映射对应多种数据库等。
mappers映射器
这里是告诉MyBatis 去哪寻找映射SQL 的语句。可以使用类路径中的资源引用,或者使用字符,输入确切的URL 引用。
例如:
Xml代码
1
2
3
4
5
|
< mappers >
< mapper resource = "com/manager/data/maps/UserMapper.xml" />
< mapper resource = "com/manager/data/maps/StudentMapper.xml" />
< mapper resource = "com/manager/data/maps/ClassMapper.xml" />
</map
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。