如果数据库操作出现异常,就需要打印日志来排错。
日志工厂会把日志工作委托实现:
SLF4J
Apache Commons Logging
Log4j 2
Log4j
JDK logging
STDOUT_LOGGING标准日志输出
在mybatis-config.xml配置:
<settings> <setting value="STDOUT_LOGGING"/> </settings>结果如下:
这地方要注意:<settings></settings> 不是随便一个地方都可以的。
在<configuration>中的东西由固定顺序,顺序为:
2 Log4jLog4j是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测试 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) 的数据。
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) 的数据。
个人博客为:
MoYu's Github Blog
MoYu's Gitee Blog