一、为什么要使用代理开发?
如下代码中调用 selectList() 方法传递的参数是映射配置文件中的 namespace.id值。存在硬编码的问题,这样写也不便于后期的维护,在使用大量sql语句时也不方便。
如果使用Mapper 代理方式(如下图)则不存在硬编码问题。
二、使用Mapper代理前的三点要求
- 定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下。如下图:(注意,在resoures中新建目录需要用\代替.)
检测是否放在同一目录:使用mvn compile一下
- 设置SQL映射文件的namespace属性为Mapper接口全限定名
- 在 Mapper 接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致
注意:
如果Mapper接口名称和SQL映射文件名称相同,并在同一目录下,则可以使用包扫描的方式简化SQL映射文件的加载。也就是将核心配置文件的加载映射配置文件的配置修改为
<mappers>
<!--加载sql映射文件-->
<!-- <mapper resource="com/itheima/mapper/UserMapper.xml"/>-->
<!--Mapper代理方式-->
<package name="com.itheima.mapper"/>
</mappers>
二、Mapper核心配置文件
- 多环境配置
在核心配置文件的 environments 标签中其实是可以配置多个 environment ,设置连接多个数据库,使用 id 给每段环境起名,在environments 中使用 default=‘环境id’ 来指定使用哪儿段配置。我们一般就配置一个 environment 即可。 - 类型别名
在映射配置文件中的 resultType 属性需要配置数据封装的类型(类的全限定名)。而每次这样写是特别麻烦的。
首先需要现在核心配置文件中配置类型别名,也就意味着给pojo包下所有的类起了别名(默认别名就是类名),不区分大小写。
内容如下: