Mybatis-04 日志、分页

Mybatis-04 日志分页 日志 1.日志工厂

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

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

SLF4J

Apache Commons Logging

Log4j 2

Log4j

JDK logging

STDOUT_LOGGING标准日志输出

在mybatis-config.xml配置:

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

结果如下:

1

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

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

2

2 Log4j

Log4j是Apache的一个开源项目,通过使用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 value="LOG4J"/> </settings> 2.4测试

3

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

4

2 使用RowBounds分页

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

2.1 Dao类 public List<user> getUserByRowbounds(); <select 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) 的数据。

5

个人博客为:
MoYu's Github Blog
MoYu's Gitee Blog

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpypgw.html