Mybatis-04 日志、分页

window.cnblogsConfig = { blogUser: ‘MoYu’, blogAvatar: ‘https://gitee.com/MoYu-zc/picgo/raw/master/img/20210213094450.jpg’, blogStartDate: ‘2020-02-09’, webpageTitleOnblur: ‘(o゚v゚)ノ Hi,Back’, webpageTitleOnblurTimeOut: 500, webpageTitleFocus: ‘(*´∇`*) 欢迎回来!’, webpageTitleFocusTimeOut: 1000, webpageIcon: “https://gitee.com/MoYu-zc/picgo/raw/master/img/20210213094450.jpg”, enable: true, // 是否开启日/夜间模式切换按钮 auto: { // 自动切换相关配置 enable: false, // 开启自动切换 dayHour: 7, // 日间模式开始时间,整数型,24小时制 nightHour: 20 // 夜间模式开始时间,整数型,24小时制 } switchDayNight: { enable: true, auto: { enable: true } }, progressBar: { id : ‘top-progress-bar’, // 请勿修改该值 color : ‘#77b6ff’, height : ‘2px’, duration: 0.2, }, loading: { rebound: { tension: 16, friction: 5, }, spinner: { id: ‘spinner’, radius: 90, sides: 3, depth: 4, colors: { background: ‘#f0f0f0’, stroke: ‘#272633’, base: null, child: ‘#272633’, }, alwaysForward: true, // When false the spring will reverse normally. restAt: 0.5, // A number from 0.1 to 0.9 || null for full rotation renderBase: false, } }, homeTopAnimationRendered: true, homeTopAnimation: { radius: 15, density: 0.2, color: ‘rgba(255,255,255, .2)’, // 颜色设置,“random” 为随机颜色 clearOffset: 0.3, }, essayTopAnimationRendered: true, essayTopAnimation: { triW : 14, triH : 20, neighbours : [“side”, “top”, “bottom”], speedTrailAppear : .1, speedTrailDisappear : .1, speedTriOpen : 1, trailMaxLength : 30, trailIntervalCreation : 100, delayBeforeDisappear : 2, colorsRandom: false, // v1.2.4 是否开启随机颜色 colors: [ ‘#96EDA6’, ‘#5BC6A9’, ‘#38668C’, ‘#374D84’, ‘#BED5CB’, ‘#62ADC6’, ‘#8EE5DE’, ‘#304E7B’ ] }, homeTopImg: [ “https://cdn.jsdelivr.net/gh/BNDong/Cnblogs-Theme-SimpleMemory@master/img/webp/home_top_bg.webp”, “https://cdn.jsdelivr.net/gh/BNDong/Cnblogs-Theme-SimpleMemory@master/img/webp/home_top_bg.webp” ], homeBannerTextType: “one”, essayTopImg: [ “https://cdn.jsdelivr.net/gh/BNDong/Cnblogs-Theme-SimpleMemory@master/img/webp/nothome_top_bg.webp”, “https://cdn.jsdelivr.net/gh/BNDong/Cnblogs-Theme-SimpleMemory@master/img/webp/nothome_top_bg.webp”, “https://gitee.com/MoYu-zc/picgo/raw/master/img/20210208190902.jpg”, “https://gitee.com/MoYu-zc/picgo/raw/master/img/20210208190954.jpg”, ], codeMaxHeight: true, codeLineNumber: true, essayCode: { fontFamily: “‘Ubuntu Mono’,monospace”, // 代码框字体 fontSize: “14px” // 代码框字体大小 }, }

MoYu

何德何能,何其荣幸

Mybatis-04 日志、分页

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) 的数据。

posted @ 2021-02-19 14:38 MoYu-zc阅读( 0 )  评论( 0 ) 编辑

Copyright © 2021 MoYu-zc

Powered by .NET 5.0 on Kubernetes

博客园精华区
我还没有学会写个人说明!
上一篇

现实版盗梦空间:最新研究发现,与做梦的人进行实时对话是可能的

下一篇

每日优鲜已启动IPO计划 去年底刚融资20亿元

你也可能喜欢

评论已经被关闭。

插入图片