Hibernate(四):Hello World
- 下载hibernate开发包:
在本章之前需要继承hibernate开发插件到eclipse,详细操作请参考我的博文:《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文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost/hibernate_01</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.current_session_context_class">thread</property>
<mapping resource="com/dx/hibernate5/test/News.hbm.xml" />
<mapping class="com.dx.hibernate5.test.News" />
</session-factory>
</hibernate-configuration>
备注:关于"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

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2017-4-14 18:41:14 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="com.dx.hibernate5.test.News" table="NEWS">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<generator class="native" />
</id>
<property name="author" type="java.lang.String">
<column name="AUTHOR" />
</property>
<property name="content" type="java.lang.String">
<column name="CONTENT" />
</property>
<property name="createDate" type="java.util.Date">
<column name="CREATEDATE" />
</property>
</class>
</hibernate-mapping>
新建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..."); }
}
Hibernate(四):Hello World的更多相关文章
- hibernate(四) 双向多对多映射关系
序言 莫名长了几颗痘,真TM疼,可能是现在运动太少了,天天对着电脑,决定了,今天下午花两小时去跑步了, 现在继上一章节的一对多的映射关系讲解后,今天来讲讲多对多的映射关系把,明白了一对多,多对多个人感 ...
- Hibernate(四)之对象状态及一级缓存
一.Hibernate中的对象状态 1.1.瞬时态(临时态) 没有与Hibernate产生关联 与数据库中的记录没有产生关联(有关联就是与数据库中表的id相对应) 获得:一般都只直接创建(new) 瞬 ...
- Hibernate(四)结构-基础语义和事务
一.基础语义 核心: Configuration SessionFactory Session 二.Configuration Configuration类负责管理Hibernate的配置信息,Hib ...
- hibernate(四)__由表逆向创建Domain对象和对象关系映射文件
之前我们是手写Domain对象和对象关系映射文件->然后生成数据库中的Table. 现在我们反过来先在数据库中建好Table->然后用工具生成Domain对象和对象关系映射文件. 步骤: ...
- Hibernate四 批量处理
Hibernate批量处理一 批量插入将很多条记录插入数据库时,Hibernate通常会采用以下做法:public void test() { for(int i=0;i<1000;i++){ ...
- Hibernate(四)——缓存策略+lazy
Hibernate作为和数据库数据打交道的框架,自然会设计到操作数据的效率问题,而对于一些频繁操作的数据,缓存策略就是提高其性能一种重要手段,而Hibernate框架是支持缓存的,而且支持一级和二级两 ...
- ORM框架Hibernate (四) 一对一单向、双向关联映射
简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...
- ssh架构之hibernate(四)二级缓存
二级缓存使用步骤: 1.拷贝jar包 2.配置Hibernate.cfg.xml文件 a.#开启二级缓存 hibernate.cache.use_second_level_cache=true b.# ...
- Hibernate(四)
==================================投影(查询)=============================投影查询:查询一个持久化类的一个或多个属性值 1.将每条 ...
- Hibernate(四)--延迟加载(lazyload)
hibernate中的延迟加载(lazyload)分属性的延迟加载和关系的延迟加载 属性的延迟加载: 当使用load的方式来获取对象的时候,只有访问了这个对象的属性,hibernate才会到数据库中进 ...
随机推荐
- linux性能调试之iostat
iostat用来监控调试linux系统的IO性能. 一般用法: iostat -xdct time_interval count [disk] -x:显示扩展统计项,如果不使用-x参数只会打印基本统计 ...
- django初探-创建简单的博客系统(二)
上篇django初探-创建简单的博客系统(一)已经记录了Django实现博客的发布的整个过程,接下来继续说明博客标题和内容的显示. 显示博客详细 将博客内容保存到数据库还不是发布博客的终极目的,博客一 ...
- Shell 读取用户输入
14.2 读取用户输入 14.2.1 变量 上一章我们谈到如何定义或取消变量,变量可被设置为当前shell的局部变量,或是环境变量.如果您的shell脚本不需要调用其他脚本,其中的变量通常设置为脚 ...
- 【Python】排列组合itertools & 集合set
■itertools 利用python的itertools可以轻松地进行排列组合运算 itertools的方法基本上都返回迭代器 比如 •itertools.combinations('abcd',2 ...
- 数据库 --> SQL 和 NoSQL 的区别
SQL 和 NoSQL 的区别 一.概念 SQL (Structured Query Language) 数据库,指关系型数据库.主要代表:SQL Server,Oracle,MySQL(开源), ...
- Matlab绘图基础——散点生成三角网(TIN)
%例一:二维三角网TIN模型的生成 X=rand(10,2)*5; dt=DelaunayTri(X(:,1),X(:,2)); %生成三角网 triplot(dt);hold on; ...
- spring学习笔记二 注解及AOP
本节需要导入spring-aop包 注解 使用注解的目的是为了代替配置,在使用注解时,省略键时,则是为value赋值. 扫描某个包下的所有类中的注解 <?xml version="1. ...
- web服务器学习1---httpd-2.4.29源码手动编译安装
环境准备: 系统:CentOS 7.4 软件:httpd-2.4.29 一 Apache主要特点 apache服务器在功能,性能和安全性等方面表现比较突出,可以较好地满足web服务器地应用需求.主要 ...
- C语言博客作业—指针
一.PTA实验作业 题目1: 求出数组中最大数和次最大数 1. 本题PTA提交列表 2. 设计思路 定义max表示范围数组中的最大数(初值设为a[0]),z表示找到的元素在数组中的位置: 定义指针*b ...
- DML数据操作语言之查询(一)
1.select语句基础 基本语句格式: select <列名>,.... from <表名>; select子句中列举出希望从表中查询出的列的名称,from子句则指定了选取 ...