- 下载hibernate开发包:
在本章之前需要继承hibernate开发插件到eclipse,详细操作请参考我的博文:《》
官网地址:http://hibernate.org/
下载页面:
下载的版本是Hibernate5.2.9(hibernate-release-5.2.9.Final.zip)
解压下载的开发包。
- 新建HelloWorld工程:
在eclipse新建project工程,工程名:Hibernate_01
在工程根目录下新建一个lib文件夹,hibernate-release-5.2.9.Final.zip解压目录是:D:\Work\Java\hibernate-release-5.2.9.Final,把D:\Work\Java\hibernate-release-5.2.9.Final\lib\required下的所有jar包拷贝到工程新建的lib文件夹下。
找到mysql的开发包,并拷贝到lib文件夹下。
选中lib文件夹下的所有jar包,右键菜单-》Build Path->Add to Build Path。
新建hibernate.cfg.xml文件
root 123456 com.mysql.jdbc.Driver jdbc:mysql://localhost/hibernate_01 org.hibernate.dialect.MySQL5InnoDBDialect true true update thread
备注:关于"hibernate.hbm2ddl.auto"可选项包括:update|create| create-drop |validate
--create:会根据.hbm.xml文件来生成数据表,但是每次运行都会删除上一次的表,重新生成表,那怕二次没有任何改变。
--create-drop:会根据.hbm.xml文件来生成数据表,但是SessionFactory一旦关闭,表就被自动删除。
--update:(最常用的一种配置选择,)会根据.hbm.xml文件来生成数据表,但如果.hbm.xml文件和数据库中对应的数据表的表结构不同,Hibernate将更新数据表结构,但不会删除已有的行和列。
--validate:会和数据库中的表进行比较,若.hbm.xml文件中的列在数据表中不存在,则会抛出异常。
新建News.java
package com.dx.hibernate5.test;import java.util.Date;public class News { private Integer id; private String author; private String content; private Date createDate; public News() { } public News(String author, String content, Date createDate) { super(); this.author = author; this.content = content; this.createDate = createDate; } public News(Integer id, String author, String content, Date createDate) { super(); this.id = id; this.author = author; this.content = content; this.createDate = createDate; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getAuthor() { return author; } public void setAuthor(String author) { this.author = author; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } public Date getCreateDate() { return createDate; } public void setCreateDate(Date createDate) { this.createDate = createDate; } @Override public String toString() { return "News [id=" + id + ", author=" + author + ", content=" + content + ", createDate=" + createDate + "]"; }}
新建News.hbm.xml
新建HelloWorld.java
package com.dx.hibernate5.test;import java.util.Date;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.boot.Metadata;import org.hibernate.boot.MetadataSources;import org.hibernate.boot.model.naming.ImplicitNamingStrategyComponentPathImpl;import org.hibernate.boot.registry.StandardServiceRegistry;import org.hibernate.boot.registry.StandardServiceRegistryBuilder;public class HelloWord { public static void main(String[] args) { // 1、创建一个SessionFactory对象 // Configuration就是代表着hibernate的那个xml配置文件对象,如果configure方法中没有参数的话,默认是就是hibernate.cfg.xml。 // Configuration conf = new Configuration().configure(); // 服务注册,这是使用创建者模式,根据配置文件中的配置字段来构建注册服务(这应该是hibernate架构中注册服务的通用流程)。 // ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder() // .applySettings(conf.getProperties()) // .build(); // 使用实例化好了的注册服务,使用Configuration中的工厂模式实例化了SessionFactory // SessionFactory sf = conf.buildSessionFactory(serviceRegistry); // 如果你用的是Hibernate4的版本,这样做完全OK的,运行的时候不会报MappingException。 // 但是如果你使用Hibernate5的版本,就会报错。那么Hibernate5应该怎样构建SessionFactory呢,如下: // 和V4版本比,V5版本看不到configure对象了。直接使用创建者模式构建出了标准服务注册对象 StandardServiceRegistry standardRegistry = new StandardServiceRegistryBuilder() .configure() .build(); // 这个对象metadata对象应该扮演了一个万金油的角色,使用以上的注册对象作为入参构建这个对象 Metadata metadata = new MetadataSources(standardRegistry) .getMetadataBuilder() .applyImplicitNamingStrategy(ImplicitNamingStrategyComponentPathImpl.INSTANCE) .build(); // 最后由这个metadata使用构建出sessionFactory SessionFactory sessionFactory = metadata.getSessionFactoryBuilder().build(); // 2、创建一个Session对象 Session session = sessionFactory.getCurrentSession(); // 3、开启事物 Transaction transaction = session.beginTransaction(); // 4、执行保存操作 News news = new News("admin", "Hello Hibernate...", new Date()); session.save(news); // 5、提交事物 transaction.commit(); // 6、关闭Session对象 session.close(); // 7、关闭SessionFactory对象 sessionFactory.close(); System.out.println("Complete..."); }}