文章目录
- SqlMapConfig.xml中配置的内容和顺序如下
- properties(属性)
- SqlMapConfig.xml引用如下
- typeAliases(类型别名)
- mybatis支持别名:
- 自定义别名
- mappers(映射器)
- Mapper引入映射器的几种方法:
- 1.通过resource属性引入classpath路径的相对资源
- 2.mapper标签,通过url引入网络资源或者本地磁盘资源
- 3.使用mapper接口类路径
- 4. 注册指定包下的所有mapper接口
- xml配置
SqlMapConfig.xml中配置的内容和顺序如下
- properties(属性)
- settings(全局配置参数):二级缓存(容易出现高并发问题)中用到以及被启用,被分布式其他所取代
- typeAliases(类型别名)typeHandlers(类型处理器)objectFactory(对象工厂)plugins(插件)
- environments(环境集合属性对象) environment(环境子属性对象)
- transactionManager(事务管理)
- dataSource(数据源)
- mappers(映射器)
properties(属性)
注意: MyBatis 将按照下面的顺序来加载属性:
在 properties 元素体内定义的属性首先被读取。 然后会读取properties 元素中resource或 url 加载的属性,它会覆盖已读取的同名属性。
db.properties配置文件内容如下:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8
jdbc.username=root
jdbc.password=root
SqlMapConfig.xml引用如下
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 是用resource属性加载外部配置文件 --><properties resource="db.properties"><!-- 在properties内部用property定义属性 --><!-- 如果外部配置文件有该属性,则内部定义属性被外部属性覆盖 --><property name="jdbc.username" value="root123" /><property name="jdbc.password" value="root123" /></properties><!-- 和spring整合后 environments配置将废除 --><environments default="development"><environment id="development"><!-- 使用jdbc事务管理 --><transactionManager type="JDBC" /><!-- 数据库连接池 --><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}" /><property name="url" value="${jdbc.url}" /><property name="username" value="${jdbc.username}" /><property name="password" value="${jdbc.password}" /></dataSource></environment></environments><!-- 加载映射文件 --><mappers><mapper resource="sqlmap/User.xml" /><mapper resource="mapper/UserMapper.xml" /></mappers>
</configuration>
typeAliases(类型别名)
mybatis支持别名:
别名 映射的类型
_byte byte
_long long
_short short
_int int
_integer int
_double double
_float float
_boolean boolean
string String
byte Byte
long Long
short Short
int Integer
integer Integer
double Double
float Float
boolean Boolean
date Date
decimal BigDecimal
bigdecimal BigDecimal
map Map
自定义别名
在SqlMapConfig.xml中配置如下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!-- 是用resource属性加载外部配置文件 --><properties resource="db.properties"><!-- 在properties内部用property定义属性 --><property name="jdbc.username" value="root123" /><property name="jdbc.password" value="root123" /></properties><typeAliases><!-- 单个别名定义 --><typeAlias alias="user" type="cn.itcast.mybatis.pojo.User" /><!-- 批量别名定义,扫描整个包下的类,别名为类名(大小写不敏感) --><package name="cn.itcast.mybatis.pojo" /><package name="其它包" /></typeAliases><!-- 和spring整合后 environments配置将废除 --><environments default="development"><environment id="development"><!-- 使用jdbc事务管理 --><transactionManager type="JDBC" /><!-- 数据库连接池 --><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}" /><property name="url" value="${jdbc.url}" /><property name="username" value="${jdbc.username}" /><property name="password" value="${jdbc.password}" /></dataSource></environment></environments><!-- 加载映射文件 --><mappers><mapper resource="sqlmap/User.xml" /><mapper resource="mapper/UserMapper.xml" /></mappers>
</configuration>
在mapper.xml配置文件中,就可以使用设置的别名了
别名大小写不敏感
mappers(映射器)
Mapper引入映射器的几种方法:
1.通过resource属性引入classpath路径的相对资源
如:
<!-- Using classpath relative resources -->
<mappers><mapper resource="org/mybatis/builder/AuthorMapper.xml"/><mapper resource="org/mybatis/builder/BlogMapper.xml"/><mapper resource="org/mybatis/builder/PostMapper.xml"/>
</mappers>
2.mapper标签,通过url引入网络资源或者本地磁盘资源
<!-- Using url fully qualified paths -->
<mappers><mapper url="file:///var/mappers/AuthorMapper.xml"/><mapper url="file:///var/mappers/BlogMapper.xml"/><mapper url="file:///var/mappers/PostMapper.xml"/>
</mappers>
3.使用mapper接口类路径
如:
<!-- Using mapper interface classes -->
<mappers><mapper class="org.mybatis.builder.AuthorMapper"/><mapper class="org.mybatis.builder.BlogMapper"/><mapper class="org.mybatis.builder.PostMapper"/>
</mappers>
注意:此种方法要求mapper接口名称和mapper映射文件名称相同,且放在同一个目录中。
4. 注册指定包下的所有mapper接口
如:
<!-- Register all interfaces in a package as mappers -->
<mappers><package name="org.mybatis.builder"/>
</mappers>
注意:此种方法要求mapper接口名称和mapper映射文件名称相同,且放在同一个目录中。
xml配置
<!-- 加载映射文件的时候用到 --><mappers><!-- <mapper class="com.mapper.mapper"/> 使用这种方式加载mapper.xml必须把该xml文件放在mapper包下才能并且与mapper类名相同加载出来 。<package name=""/>package同理,用分最多的是package避免配置多个麻烦--><mapper resource="User.xml"/><mapper resource="mapper.xml"/> <!-- <package name="com.mapper"/> package用法,只需要把xml文件放在该mapper包下就会被扫描到,名称没有要求--></mappers>