MyBatis学习总结第四篇
一、解决属性名和字段名不一致的问题
问题:数据库字段名与实体类中的属性名不一致时,会导致查询结果为空。
例如,数据库中为"password",实体类中为"pwd"。查询时会出现以下结果:
为了解决这种问题,有以下两个方法。
-
方法一:使用别名(不推荐,没意义)
-
方法二:使用resultMap结果集映射(推荐)
-
官方文档总结:
- resultMap 元素是 MyBatis 中最重要最强大的元素。
- ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
- ResultMap 的优秀之处 —— 你完全可以不用显式地配置它们。
- 然后在引用它的语句中设置 resultMap 属性就行了(注意我们去掉了 resultType 属性)。
二、MyBatis内置的日志工厂
在项目中,我们可以通过日志工厂控制日志信息输出到控制台,从而对数据库产生异常进行排错。常用的日志有SLF4J、LOG4J…
在mybatis中具体使用哪一个日志实现,在设置中设定。
2.1 使用STDOUT_LOGGING
- 在核心配置文件mybatis-config.xml中配置日志信息。注意放在properties属性之后,typeAliases属性之前。
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
- 控制台显示日志信息。
2.2使用LOG4J
- 先导入LOG4J的依赖
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
- 资源文件resources下创建log4j.properties配置文件
- 配置log4j为日志的实现
<settings>
<setting name="logImpl" value="LOG4J"/>
</settings>
- 控制台显示
三、使用Limit分页
- UserMapper接口
//分页
List<User> getUserByLimit(Map<String,Integer> map);
- UserMapper.xml映射文件
<!--分页查询-->
<select id="getUserByLimit" parameterType="map" resultType="user" resultMap="UserMap">
select * from mybatis.user1 limit #{startIndex},#{pageSize}
</select>
- 测试类
public void getUserByLimit(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
HashMap<String, Integer> map = new HashMap<String, Integer>();
map.put("startIndex",0);
map.put("pageSize",2);
List<User> userList = mapper.getUserByLimit(map);
for (User user : userList) {
System.out.println(user);
}
}
- 结果
四、使用RowBounds 分页
了解即可。不需要在 sql 语句中写 limit,只需通过Java代码层面实现分页。
五、使用MyBatis插件分页
后期学习。