相关章节:
Mybatis使用xml方式配置
Mybatis使用xml方式配置(二)
Mybatis使用xml方式配置(三)
官网地址:https://mybatis.org/mybatis-3/zh/configuration.html
1. 作用域(Scope)和生命周期
SqlSessionFactoryBuilder
:这个类一旦创建了SqlSessionFactory
,就不再需要它了。因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。SqlSessionFactory
:一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。因此SqlSessionFactory
的最佳作用域是应用作用域。 有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式。SqlSession
:每个线程都应该有它自己的SqlSession
实例。SqlSession
的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。换句话说,每次收到 HTTP 请求,就可以打开一个 SqlSession,返回一个响应后,就关闭它。 这个关闭操作很重要!!!
2. 结果映射resultMap
resultMap
元素是 MyBatis
中最重要最强大的元素。我们在UserMapper.xml
中查询用户的时候,返回resultType
的时候,如:
<select id="findUserInfoByID" parameterType="int" resultType="com.weizu.pojo.UserInfo">
select * from userinfo where userid = #{userid}
</select>
MyBatis
会在幕后自动创建一个ResultMap
,再根据属性名来映射列到JavaBean
的属性上。比如这种实现,在UserMapper.xml
文件中:
<resultMap id="mapUserInfo" type="com.weizu.pojo.UserInfo">
<id property="userid" column="userid" />
<result property="username" column="username"/>
<result property="passwd" column="passwd"/>
</resultMap>
<select id="findUserInfoByID" parameterType="int" resultMap="mapUserInfo">
select * from userinfo where userid = #{userid}
</select>
测试:
@org.junit.Test
public void find(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserDao mapper = sqlSession.getMapper(UserDao.class);
// 查找,传入基本类型
UserInfo userInfoByID = mapper.findUserInfoByID(234);
System.out.println(userInfoByID); // success
}
同时,使用resultMap
可以映射pojo
实体对象和数据库表字段不一致情况;当然,最简单的解决方式是在sql
语句中使用别名来解决映射字段名不一致问题;
同时,使用resultMap
也可以解决多表查询时候的映射问题;也就是文档中的高级结果映射。
https://www.bilibili.com/video/BV1NE411Q7Nx?p=9
https://www.bilibili.com/video/BV1NE411Q7Nx?p=10