环境配置(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>

02mybatis-config配置

必须按照从上到下的顺序。

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 的运行时行为。
02mybatis-config配置

查询数据的时候,查不到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>

02mybatis-config配置

类型别名(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>

02mybatis-config配置

每一个在包 com.leizi.pojo 中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。

若有注解,则别名为其注解值。

@Alias("user")
public class User {
    ...
}

02mybatis-config配置

映射器(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>

相关文章: