MyBatis学习总结第四篇

一、解决属性名和字段名不一致的问题

问题:数据库字段名与实体类中的属性名不一致时,会导致查询结果为空。
例如,数据库中为"password",实体类中为"pwd"。查询时会出现以下结果:
密码为空
为了解决这种问题,有以下两个方法。

  1. 方法一:使用别名(不推荐,没意义)
    没意义

  2. 方法二:使用resultMap结果集映射(推荐)
    结果集映射

  3. 官方文档总结:

  • 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插件分页

后期学习。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值