Mybatis-04 日志、分页

日志

1.日志工厂

如果数据库操作出现异常,就需要打印日志来排错。

日志工厂会把日志工作委托实现:

  • SLF4J
  • Apache Commons Logging
  • Log4j 2
  • Log4j
  • JDK logging

STDOUT_LOGGING标准日志输出

mybatis-config.xml配置:

<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>

结果如下:

这地方要注意:<settings></settings> 不是随便一个地方都可以的。

<configuration>中的东西由固定顺序,顺序为:

2 Log4j

Log4jApache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI)组件

2.1 导包

<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

2.2 配置文件

创建配置文件,名称一定要为:log4j.properties

#将等级为DEBUG的日志信息输出到console和file这两个目的地,console和file的定义在下面的代码
log4j.rootLogger=DEBUG,console,file #控制台输出的相关设置
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n #文件输出的相关设置
log4j.appender.file = org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./log/Test.log
log4j.appender.file.MaxFileSize=10mb
log4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yy-MM-dd}][%c]%m%n #日志输出级别
log4j.logger.org.mybatis=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

2.3 在mybatis-config.xml配置

<settings>
<setting name="logImpl" value="LOG4J"/>
</settings>

2.4测试

2.5简单使用

日志对象,参数是当前类的Class对象

static Logger logger = Logger.getLogger(UserMapperTest.class);

日志级别

logger.info("进入了testLog4j方法");
logger.debug("进入了testLog4j方法");
logger.error("进入了testLog4j方法");

分页

1 使用Limit分页

语法:
select *from user limit startIndex,pageSize;
select *from user limit n; #[0,n)

注意:表的记录索引从0开始

1.1 Dao类

 public List<user> getUserListByLimit(Map map);
<select id="getUserListByLimit" parameterType="map" resultType="pojo.user">
select * from mybatistest.user limit #{min},#{max}
</select>

1.2 测试

public class Test {

    @org.junit.Test
public void test(){
//第一步:获得SqlSession对象
SqlSession sqlSession = mybatis_util.getSqlSession();
//执行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
HashMap<String, Object> map = new HashMap<String, Object>();
map.put("min",0);
map.put("max",2);
List<user> userList = mapper.getUserListByLimit(map);
for (user user : userList) {
System.out.println(user);
}
//关闭SqlSession
sqlSession.close();
}
}

上述测试,结果会出现索引 [0,2) 的数据。

2 使用RowBounds分页

不在Sql层面操作,在java代码层面实现分页

2.1 Dao类

public List<user> getUserByRowbounds();
<select id="getUserByRowbounds" resultType="pojo.user">
select *from mybatistest.user
</select>

2.2测试

public class Test {

    @org.junit.Test
public void test(){
//第一步:获得SqlSession对象
SqlSession sqlSession = mybatis_util.getSqlSession();
//执行SQL
UserDao mapper = sqlSession.getMapper(UserDao.class);
RowBounds rowBounds = new RowBounds(0,2);
List<user> userList = sqlSession.selectList("com.Dao.UserDao.getUserByRowbounds", null, rowBounds);
for (user user : userList) {
System.out.println(user);
}
//关闭SqlSession
sqlSession.close();
}
}

结果也是会出现索引 [0,2) 的数据。

个人博客为:

MoYu's Github Blog

MoYu's Gitee Blog

最新文章

  1. clicaptcha中文点击验证码开发经验总结
  2. MongoDB的学习和使用(固定集合[Capped Collections])
  3. 发布HTML5 RTS游戏-古代战争
  4. ajax 异步调用把返回值赋给一个全局变量的用法,最主要的就是把async属性改为 false,
  5. sql server 2005全角与半角字符转换
  6. 为什么要CGI
  7. poj 2049 Finding Nemo(优先队列+bfs)
  8. 深入浅出—JAVA(4)
  9. &lt;Natural Language Processing with Python&gt;学习笔记二
  10. Git 远程分支的pull与push
  11. jquery实现网页倒计时
  12. CentOS下SparkR安装部署:hadoop2.7.3+spark2.0.0+scale2.11.8+hive2.1.0
  13. PWA初体验
  14. 【翻译】在Ext JS集成第三方库
  15. vscode下面开发vue.js项目
  16. Spring MVC 使用介绍(十五)数据验证 (二)依赖注入与方法级别验证
  17. jq获取页面url后边带的参数
  18. asmx 接收数据过大 发生错误
  19. 优化-最小化损失函数的三种主要方法:梯度下降(BGD)、随机梯度下降(SGD)、mini-batch SGD
  20. Centos中彻底删除Mysql(rpm、yum安装的情况)

热门文章

  1. python 中excel表格的操作【转载】
  2. Excel 一张表最多能装下多少行多少列数据?
  3. 应急响应-PDCERF模型 (转)
  4. js将金额转成大写金额
  5. C - 小希的迷宫
  6. 2020牛客暑期多校训练营(第五场)B - Graph (异或 最小生成树 分治 Trie)
  7. qmh的测试1
  8. Redis 主从复制(Replication)
  9. wordpress 插件安装 Too Many Requests
  10. 5分钟看懂Code128条形码