做者:孤傲苍狼 java
以前,咱们是直接将数据库的链接配置信息写在了MyBatis的conf.xml文件中,以下:mysql
<?xml version="1.0" encoding="UTF-8"?>
sql
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
数据库
<configuration>
mybatis
<environments default="development">
app
<environment id="development">
dom
<transactionManager type="JDBC"/>
ide
<!-- 配置数据库链接信息 -->
url
<dataSource type="POOLED">
spa
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
<property name="username" value="root"/>
<property name="password" value="XDP"/>
</dataSource>
</environment>
</environments>
</configuration>
其实咱们彻底能够将数据库的链接配置信息写在一个properties文件中,而后在conf.xml文件中引用properties文件,具体作法以下:
一、在src目录下新建一个db.properties文件,以下图所示:
在db.properties文件编写链接数据库须要使用到的数据库驱动,链接URL地址,用户名,密码,以下:
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis
name=root
password=XDP
二、在MyBatis的conf.xml文件中引用db.properties文件,以下:
<?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>
<!-- 引用db.properties配置文件 -->
<properties resource="db.properties"/>
<!--
development : 开发模式
work : 工做模式
-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<!-- 配置数据库链接信息 -->
<dataSource type="POOLED">
<!-- value属性值引用db.properties配置文件中配置的值 -->
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${name}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
</configuration>
以前,咱们在sql映射xml文件中的引用实体类时,须要写上实体类的全类名(包名+类名),以下:
<!-- 建立用户(Create) -->
<insert id="addUser" parameterType="me.gacl.domain.User">
insert into users(name,age) values(#{name},#{age})
</insert>
parameterType="me.gacl.domain.User"这里写的实体类User的全类名me.gacl.domain.User,每次都写这么一长串内容挺麻烦的,而咱们但愿可以简写成下面的形式
<insert id="addUser2" parameterType="_User">
insert into users(name,age) values(#{name},#{age})
</insert>
parameterType="_*User"这样写就简单多了,为了达到这种效果,咱们须要在conf.xml文件中为实体类="me.gacl.domain.User"定义一个别名为"_*User",具体作法以下:在conf.xml文件中标签中添加以下配置:
<typeAliases>
<typeAlias type="me.gacl.domain.User" alias="_User"/>
</typeAliases>
这样就能够为me.gacl.domain.User类定义了一个别名为_User,之后_User就表明了me.gacl.domain.User类,这样sql映射xml文件中的凡是须要引用me.gacl.domain.User类的地方均可以使用_User来代替,这就达到了一个简化实体类引用的目的。
除了可使用这种方式单独为某一个实体类设置别名以外,咱们还可使用以下的方式批量为某个包下的全部实体类设置别名,以下:
<!-- 配置实体类的别名,配置实体类别名的目的是为了在引用实体类时可使用实体类的别名来代替实体类,达到简写的目的 -->
<typeAliases>
<!-- 为实体类me.gacl.domain.User配置一个别名_User-->
<!-- <typeAlias type="me.gacl.domain.User" alias="_User"/> -->
<!-- 为me.gacl.domain包下的全部实体类配置别名,MyBatis默认的设置别名的方式就是去除类所在的包后的简单的类名
好比me.gacl.domain.User这个实体类的别名就会被设置成User
-->
<package name="me.gacl.domain"/>
</typeAliases>
就表示为这个包下面的全部实体类设置别名。MyBatis默认的设置别名的方式就是去除类所在的包后的简单的类名,好比me.gacl.domain.User这个实体类的别名就会被设置成User。
END