博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hibernate(三)基本配置,log4j、JUnit配置
阅读量:6345 次
发布时间:2019-06-22

本文共 4566 字,大约阅读时间需要 15 分钟。

一、基本配置

  1、<property name="hbm2ddl.auto">update</property>

  改项配置有4个选项:

  validate:当创建好表,当我们操纵数据之前会检查数据库中表与配置文件对应上;

  update:如果我们添加了新的属性,而数据库中的表中没有该列,hibernate会帮我添加该字段(或者是我们在实体类中增加一个属性(比如在Student类中添加一个属性sex)hibernate会帮我们添加);

  create:启动时如果对应表存在则drop掉然后再创建,如果数据库没有对应的表,hibernate会自动帮我们创建;

  下图是设置为create时日志

  

  create-drop:只要关闭SessionFactory,hibernate会自动删除表;

 

  2、如果表名与类名不一致则可以在实体类上的@Entity注解下边再添加@Table(name="teacher")

如果使用配置文件配置映射的话可以在class标签上添加属性table="teacher"

 

  3、注解@Basic可不加,默认会把实体类中所有属性映射到数据库表。所有没有定义注解的属性都会等价为在上边添加了@Basic

 

  4、如果字段名与属性名不相同,采用注解配置的话则在属性get方法上添加@Cloumn(name="_name"),如果采用配置文件方式则添加cloumn属性

 

  5、如果不想一个实体类的属性不参与映射,则在get方法上添加注解@Transient,xml配置文件的话就不要写这个属性即<property .../>这个东西不用写进去

 

  6、映射日期与时间,指定时间精度@Temporal(注:如果注解中需要写value="..."则可以省略value直接写属性值)

如果只记日期不记录时间则可以在属性的get方法上写注解@Temporal(TemporalType.DATA)

如果采用配置文件方式配置映射则在配置文件class标签下指定的属性对应的<property>标签中添加属性type="date",或者type="time"(只显示时间不显示日期),type用于指定类型

 

  7、映射枚举类型@Enumerated

如果要映射枚举类型可以在属性的get方法上添加注解@Enumerated(EnumType.STRING)(在数据库中该属性对应的字段为varchar类型)

如果EnumType.ORDINAL就会把下标值存进去(即在数据库中该属性对应的字段为integer类型)

 

  8、注解可以放在实体类的成员变量上,与放在get方法上起到相同的效果

 

二、配日志环境显示DDL

  首先导入slf4j-api-1.6.1.jar,然后下载sjf4j(1.6.1)和log4j(1.2.17)解压。然后导入slf4j-log4j12-1.6.1-jar、log4j-1.2.17.jar到hibernate下

  然后从hibernate示例中copy一份log4j配置文件到src目录下

log4j.properties例:

### direct log messages to stdout ###log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.outlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### direct messages to file hibernate.log ####log4j.appender.file=org.apache.log4j.FileAppender#log4j.appender.file.File=hibernate.log#log4j.appender.file.layout=org.apache.log4j.PatternLayout#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n### set log levels - for more verbose logging change 'info' to 'debug' ###log4j.rootLogger=warn, stdout#log4j.logger.org.hibernate=infolog4j.logger.org.hibernate=debug### log HQL query parser activity#log4j.logger.org.hibernate.hql.ast.AST=debug### log just the SQL#log4j.logger.org.hibernate.SQL=debug### log JDBC bind parameters ###log4j.logger.org.hibernate.type=info#log4j.logger.org.hibernate.type=debug### log schema export/update ###log4j.logger.org.hibernate.tool.hbm2ddl=debug### log HQL parse trees#log4j.logger.org.hibernate.hql=debug### log cache activity ####log4j.logger.org.hibernate.cache=debug### log transaction activity#log4j.logger.org.hibernate.transaction=debug### log JDBC resource acquisition#log4j.logger.org.hibernate.jdbc=debug### enable the following line if you want to track down connection ###### leakages when using DriverManagerConnectionProvider ####log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace

执行StudentTest测试类,就可以在控制台看到打印的日志了,如果在hibernate.cfg.xml设置<property name="hbm2ddl.auto">create</property>的话就可以看到建表语句了:

 

当然,通过设置配置文件更改日志输出的内容(级别),将除log4j.logger.org.hibernate.tool.hbm2ddl=debug以外的配置全部屏蔽就只会在控制台中看到ddl了

 

三、搭建Junit

  参见另一篇文章:Junit4使用

  1、首先下载解压,然后bulid path->add libraries->user library->user libraries->new然后输入MyJunit然后把刚才下载的Junit的包加进去

  2、项目根目录下创建一source folder名为test,然后因为要对Student、Teacher类进行测试(注:并不是要测试这两个类,只是会用这两个类进行测试)所有在test下创建包为cn.orlion.hibernate.model

  3、创建测试类,可以让eclipse帮我们创建:在测试包右键->new->Junit Test Case-填入测试的类:

然后创建测试方法testTeacherSave()

package cn.orlion.hibernate.model;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.cfg.AnnotationConfiguration;import org.hibernate.cfg.Configuration;import org.junit.AfterClass;import org.junit.BeforeClass;import org.junit.Test;public class TeacheTest {        private static SessionFactory sf = null;        @BeforeClass    public static void beforeClass(){                sf = new AnnotationConfiguration().configure().buildSessionFactory();    }    @Test    public void testTeacherSave() {        Teacher t = new Teacher();                t.setName("test1");        t.setTitle("title1");                Session session = sf.openSession();                session.beginTransaction();        session.save(t);        session.getTransaction().commit();                session.close();            }        @AfterClass    public static void afterclass(){        sf.close();    }}

testTeacherSave()方法上右键Run as-> Junit test可以看绿条,success。

 

四、showsql formatsql

  1、hibernate.cfg.xml中配置<property name="show_sql">true</property>就会在控制台中打印出sql语句

  2、<property name="format_sql">true</property>就会在控制台中打印出格式化后的sql语句,而不是单单在一行显示,更加直观友好:

  

 

转载于:https://www.cnblogs.com/orlion/p/5041335.html

你可能感兴趣的文章
Linux指令面试题01-进程查看与终止
查看>>
C# Lambda表达式
查看>>
Spring 教程(三) 环境设置
查看>>
指针简单用法
查看>>
求整数数列螺旋存储中任意数到数据1的曼哈顿距离 spiral_memory
查看>>
550.键盘行
查看>>
WPF的转换器中使用Brush应注意问题
查看>>
MySQL循环语句之while循环测试
查看>>
69.资金管理-税率表管理extjs 页面
查看>>
Android 安全更新的发展与沿革
查看>>
如何在office2010中的EXCEL表格使用求和公式
查看>>
Post Office Protocol --- pop协议
查看>>
批处理类 RunBaseBatch
查看>>
JDK12下的ArrayList源码解读 与 Vector的对比
查看>>
1111: 零起点学算法18——3个数比较大小
查看>>
CentOS Apache+Tomcat 整合配置(两种办法)
查看>>
vmware mac 系统进入恢复模式 关闭SIP
查看>>
day12 Python元祖
查看>>
C语言博客作业--字符数组
查看>>
laravel 的passport Oauth 认证登录请求 的 oauth_token 重置
查看>>