【Hibernate框架开发之三】搭建Hibernate日志(slf4j转log4j)与Junit单元测试环境

简介:

 由于最新写cocos2dx动作编辑器的解析和框架所以没更新,那么从今天开始继续来学习Hibernate,那么接着第二篇文章讲解,那么首先copy,第二篇的第一个Annotation的项目改个名字“LogForHibernate”;

          首先搭建log4j环境;

第一步我们之前设置过的User Libraries继续添加打印日志相关的配置,(ps.其实日志的控制台打印,对于我们Dev来说至关重要,一方面了解当前程序运行的情况即时找到BUG出处~,另外一方面log4j日志能为我们),添加如下jar包到Himi的MyHibernate(自定义的User Libraries):

首先Himi的MyHibernate删除slf4-nop-1.5.8.jar 包,然后换成log4j的实现如下第一个jar包:

第一个jar包         /apache-log4j-1.2.15/log4j-1.2.15.jar

继续添加第二个jar包         /slf4j-1.5.8/slf4j-1.5.8/slf4j-log4j12-1.5.8.jar

(这个slf4j-log4j12-1.5.8.jar,其实就是将slf4j 转换成log4j 日志的“适配器”;)

接下来我们需要配置一下log4j的配置文件,默认这个配置文件名,约定俗成:“log4j.properties”

不用手动创建,直接到如下路径索取:

/hibernate-distribution-3.3.2.GA/project/etc/log4j.properties

copy到项目中即可,与“hibernate.cfg.xml”放置同一级目录,OK,直接运行项目观察控制台,会发现很多debug信息,有些我们先用不到,OK,打开log4j.properties配置文件,改成如下:

 


  
  
  1. ### direct log messages to stdout ### 
  2. log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
  3. log4j.appender.stdout.Target=System.out 
  4. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
  5. log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n 
  6.  
  7. ### direct messages to file hibernate.log ### 
  8. #log4j.appender.file=org.apache.log4j.FileAppender 
  9. #log4j.appender.file.File=hibernate.log 
  10. #log4j.appender.file.layout=org.apache.log4j.PatternLayout 
  11. #log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n 
  12.  
  13. ### set log levels - for more verbose logging change 'info' to 'debug' ### 
  14.  
  15. log4j.rootLogger=warn, stdout 
  16.  
  17. #log4j.logger.org.hibernate=info 
  18. #log4j.logger.org.hibernate=debug 
  19.  
  20. ### log HQL query parser activity 
  21. #log4j.logger.org.hibernate.hql.ast.AST=debug 
  22.  
  23. ### log just the SQL 
  24. #log4j.logger.org.hibernate.SQL=debug 
  25.  
  26. ### log JDBC bind parameters ### 
  27. #log4j.logger.org.hibernate.type=info 
  28. #log4j.logger.org.hibernate.type=debug 
  29.  
  30. ### log schema export/update ### 
  31. log4j.logger.org.hibernate.tool.hbm2ddl=debug 
  32.  
  33. ### log HQL parse trees 
  34. #log4j.logger.org.hibernate.hql=debug 
  35.  
  36. ### log cache activity ### 
  37. #log4j.logger.org.hibernate.cache=debug 
  38.  
  39. ### log transaction activity 
  40. #log4j.logger.org.hibernate.transaction=debug 
  41.  
  42. ### log JDBC resource acquisition 
  43. #log4j.logger.org.hibernate.jdbc=debug 
  44.  
  45. ### enable the following line if you want to track down connection ### 
  46. ### leakages when using DriverManagerConnectionProvider ### 
  47. #log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace 
  48. 这里我们只留下,log4j.logger.org.hibernate.tool.hbm2ddl=debug  ,DDL的输出即可; 
  49.  
  50. OK,Himi再次运行项目打印如下: 
  51.  
  52. 00:58:31,450  INFO SchemaExport:226 - Running hbm2ddl schema export 
  53. 00:58:31,451 DEBUG SchemaExport:242 - import file not found: /import.sql 
  54. 00:58:31,452  INFO SchemaExport:251 - exporting generated schema to database 
  55. 00:58:31,452 DEBUG SchemaExport:377 - drop table if exists People 
  56. 00:58:31,462 DEBUG SchemaExport:377 - create table People (id integer not null, age integer not null, birthday varchar(255), name varchar(255), title varchar(255), primary key (id)) 
  57. 00:58:31,565  INFO SchemaExport:268 - schema export complete 
  58. Hibernate: insert into People (age, birthday, name, title, id) values (?, ?, ?, ?, ?) 

这次看起来就非常清晰了。

//--------------Himi  分割线---------------

    下面介绍  Junit的环境搭建;

copy 刚才的"LogForHibernate"项目,换名:“JunitForHibernate”;

OK,添加所需资源jar包,这里Himi添加到项目path中的为:junit-4.7.jar 包;

下一步,右键new->JUnit Test Case,如下图:

 

然后选择我们需要测试的方法:

 

 


  
  
  1. package com.himi; 
  2.  
  3. import org.hibernate.Session; 
  4. import org.hibernate.SessionFactory; 
  5. import org.hibernate.cfg.AnnotationConfiguration; 
  6. import org.junit.AfterClass; 
  7. import org.junit.BeforeClass; 
  8. import org.junit.Test; 
  9.  
  10. public class PeopleTest { 
  11.     public static SessionFactory sf =null
  12.  
  13.     //在类始化之前执行的方法 
  14.     @BeforeClass 
  15.     public static void beforeClass(){ 
  16.         sf=new AnnotationConfiguration().configure().buildSessionFactory(); 
  17.     } 
  18.  
  19.     @Test 
  20.     public void test() { 
  21.         People people = new People();// 新建我们需要存储的类对象,并且设置其对象的一些属性 
  22.         people.setId(1); 
  23.         people.setName("Himi"); 
  24.         people.setAge(23); 
  25.         people.setTitle("CTO"); 
  26.         people.setBirthday("1990-01-01"); 
  27.  
  28.         // 这里注意了,cfg.configure()读取配置文件的时候,如果你的hibernate的文件名不采用默认的“hibernate.cfg.xml”的话,那么这里传入你定义的配置文件路径 
  29.         // buildSessionFactory();得到一个创建Session的工场 
  30.         Session ss = sf.openSession();// 这里的Session导入import 
  31.                                         // org.hibernate.Session;不要使用class经典的,因为可能会过时 
  32.         ss.beginTransaction();// OK,将操作放入事务中 
  33.         ss.save(people);// 保存你的对象 
  34.         ss.getTransaction().commit();// 得到事务并提交 
  35.  
  36.         ss.close();// Session关闭 
  37.  
  38.     } 
  39.     //在类结束之后执行的方法 
  40.     @AfterClass 
  41.     public static void afterClass(){ 
  42.         sf.close();// 工厂关闭 
  43.     } 

OK,就到这里,感冒了 早睡觉~晚安 各位;





本文转自 xiaominghimi 51CTO博客,原文链接:http://blog.51cto.com/xiaominghimi/969781,如需转载请自行联系原作者
相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
目录
相关文章
|
12月前
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `<appender>` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `<logger>` 和 `<root>` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
2795 1
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
4401 31
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
12月前
|
Java 微服务 Spring
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——使用Logger在项目中打印日志
本文介绍了如何在项目中使用Logger打印日志。通过SLF4J和Logback,可设置不同日志级别(如DEBUG、INFO、WARN、ERROR)并支持占位符输出动态信息。示例代码展示了日志在控制器中的应用,说明了日志配置对问题排查的重要性。附课程源码下载链接供实践参考。
1262 0
|
12月前
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
1090 0
|
12月前
|
Java API 开发者
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——slf4j 介绍
在软件开发中,`System.out.println()`常被用于打印信息,但大量使用会增加资源消耗。实际项目推荐使用slf4j结合logback输出日志,效率更高。Slf4j(Simple Logging Facade for Java)是一个日志门面,允许开发者通过统一方式记录日志,无需关心具体日志系统。它支持灵活切换日志实现(如log4j或logback),且具备简洁占位符和日志级别判断等优势。阿里巴巴《Java开发手册》强制要求使用slf4j,以保证日志处理方式的统一性和维护性。使用时只需通过`LoggerFactory`创建日志实例即可。
771 0
|
Java 程序员 API
Android|集成 slf4j + logback 作为日志框架
做个简单改造,统一 Android APP 和 Java 后端项目打印日志的体验。
823 1
|
9月前
|
人工智能 Java 测试技术
Spring Boot 集成 JUnit 单元测试
本文介绍了在Spring Boot中使用JUnit 5进行单元测试的常用方法与技巧,包括添加依赖、编写测试类、使用@SpringBootTest参数、自动装配测试模块(如JSON、MVC、WebFlux、JDBC等),以及@MockBean和@SpyBean的应用。内容实用,适合Java开发者参考学习。
980 0
|
5月前
|
Java 测试技术 数据库连接
【SpringBoot(四)】还不懂文件上传?JUnit使用?本文带你了解SpringBoot的文件上传、异常处理、组件注入等知识!并且带你领悟JUnit单元测试的使用!
Spring专栏第四章,本文带你上手 SpringBoot 的文件上传、异常处理、组件注入等功能 并且为你演示Junit5的基础上手体验
1034 3
|
XML Java 测试技术
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
这篇文章介绍了Spring5框架的三个新特性:支持@Nullable注解以明确方法返回、参数和属性值可以为空;引入函数式风格的GenericApplicationContext进行对象注册和管理;以及如何整合JUnit5进行单元测试,同时讨论了JUnit4与JUnit5的整合方法,并提出了关于配置文件加载的疑问。
Spring5入门到实战------17、Spring5新功能 --Nullable注解和函数式注册对象。整合JUnit5单元测试框架
|
12月前
|
Java 测试技术 Android开发
课时148:junit测试工具
课时148介绍了JUnit测试工具的使用,包括定义、配置和编写测试程序。JUnit是流行的用例测试工具,用于确保代码稳定性。
250 0