环境配置(environments):
mybatis可以配置多种环境,测试、开发等
每个sqlSessionFactory实例只能选择一种环境
还可以在创建sqlSessionFactory调用build方法时,指定第二个参数为当前sqlSession运行的环境
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream,"test");// 测试环境
mybatis默认的事务管理器就是JDBC;连接池:POOLED
属性(properties):
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 引入外部资源文件,resource:相对路径,url:绝对路径 -->
<properties resource="jdbc.properties" />
<!-- 环境:说明可以配置多个,default:指定生效的环境 -->
<environments default="development">
<!-- id:环境的唯一标识 -->
<environment >
<!-- 事务管理器,type:类型 -->
<transactionManager type="JDBC" />
<!-- 数据源:type-池类型的数据源 -->
<dataSource type="POOLED">
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
</environments>
<!-- 映射文件 -->
<mappers>
<mapper resource="UserMapper.xml" />
<mapper resource="UserDaoMapper.xml" />
</mappers>
</configuration>
必须按照从上到下的顺序。
jdbc.properties配置文件:
driver = com.mysql.jdbc.Driver
url = jdbc:mysql://127.0.0.1:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8
username = root
password = root
设置(settings)
这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。
查询数据的时候,查不到userName的信息,原因:数据库的字段名是user_name,POJO中的属性名字是userName,两端不一致,造成mybatis无法填充对应的字段信息。
驼峰匹配
mybatis-config.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:classpath路径,url:绝对路径(不建议使用) -->
<properties resource="jdbc.properties"></properties>
<settings>
<!-- 开启驼峰匹配:经典的数据库列名(多个单词下划线连接)映射到经典的java属性名(多个单词驼峰连接) -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
类型别名(typeAliases)
<!-每次resultType都需要写类的全路径:cn.leizi.mybatis.pojo.User-->
<select >
select * from tb_user
</select>
类型别名是为 Java 类型设置一个短的名字。 它只和 XML 配置有关,存在的意义仅在于用来减少类完全限定名的冗余。
在配置文件中配置类型别名
<typeAliases>
<typeAlias alias="User" type="cn.leizi.mybatis.pojo.User"/>
</typeAliases>
<!-使用类型别名为类起别名后直接写别名即可-->
<select >
select * from tb_user
</select>
以上起别名方式实体类少的时候使用,若实体类多使用包扫描,MyBatis 会在包名下面搜索需要的 Java Bean,比如:
<typeAliases>
<package name="com.leizi.pojo"/>
</typeAliases>
每一个在包 com.leizi.pojo 中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。
若有注解,则别名为其注解值。
@Alias("user")
public class User {
...
}
映射器(mappers)
定义 SQL 映射语句。 但是首先我们需要告诉 MyBatis 到哪里去找到这些语句。 Java 在自动查找这方面没有提供一个很好的方法,所以最佳的方式是告诉 MyBatis 到哪里去找映射文件。 你可以使用相对于类路径的资源引用, 或完全限定资源定位符(包括 file:/// 的 URL),或类名和包名等。
<!-- 使用相对于类路径的资源引用 -->
<mappers>
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
<mapper resource="org/mybatis/builder/BlogMapper.xml"/>
</mappers>
<!-- 使用完全限定资源定位符(URL) -->
<mappers>
<mapper url="file:///var/mappers/AuthorMapper.xml"/>
<mapper url="file:///var/mappers/BlogMapper.xml"/>
</mappers>
<!-- 使用映射器接口实现类的完全限定类名 -->
<mappers>
<mapper class="org.mybatis.builder.AuthorMapper"/>
<mapper class="org.mybatis.builder.BlogMapper"/>
</mappers>
注意:
- 接口和它的Mapper配置文件必须同名
- 接口和他的Mapper配置文件必须在同一个包下
<!-- 将包内的映射器接口实现全部注册为映射器 -->
<mappers>
<package name="org.mybatis.builder"/>
</mappers>