热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Hibernate教程(一)Hibernate简介

Hibernate简介Hibernate是一个Java对象映射关系的解决方案的ORM(Object-RelationalMapping)框架,是一个开源持久框架,由GavinKin

Hibernate简介

  • Hibernate是一个Java对象映射关系的解决方案的ORM(Object-Relational Mapping)框架,是一个开源持久框架,由Gavin King于2001年创建。为Java应用提供强大的、高性能对象持久化和查询服务。

  • Hibernate将Java类映射到数据库表,将Java数据类型映射到SQL数据类型,减轻了开发人员95%的数据持久性相关的编程任务。

  • Hibernate位于传统的Java对象和数据库服务器之间,基于适当的O/R机制和模式来处理持久化这些对象的所有工作。

《Hibernate教程(一)---Hibernate简介》 Hibernate-position

Hibernate的优势

  • Hibernate通过XML配置文件将Java类映射到数据库表,而不需要编写任何代码。
  • 提供简单的API,用于直接存储和检索数据库中的Java对象。
  • 如果数据库或任何表中有更改,只需要修改XML文件。
  • 提取我们不熟悉的SQL类型,并提供我们熟悉的Java对象。
  • Hibernate不需要应用府服务器来操作。
  • 操作复杂关联的数据库对象。
  • 使用智能抓取策略简化数据库操作。
  • 提供简单的数据查询。

Hibernate支持的数据库

Hibernate几乎支持所有的关系型数据库管理系统(RDBMS),支持的数据库如下所示:

  • HSQL Database Engine
  • DB2/NT
  • MySQL
  • PostgreSQL
  • FrontBase
  • Oracle
  • Microsoft SQL Server Database
  • Sybase SQL Server
  • nformix Dynamic Server

Hibernate架构

Hibernate架构是分层的,所以我们不需要知道底层的API,Hibernate利用数据库和配置数据向我们的应用程序提供持久性服务(和持久性对象)。

下图是Hibernate应用结构体系简要视图:

《Hibernate教程(一)---Hibernate简介》 Hibernate-hign-level

下图是Hibernate应用结构体系详细视图,包含了几个重要的核心类:

《Hibernate教程(一)---Hibernate简介》 Hibernate架构

  • Hibernate使用各种现有的Java API,如JDBC,JTA,JNDI

JDBC提供了关系数据库通用的功能抽象层,所有具有JDBC驱动程序的数据库都被Hibernate支持。
JTAJNDI允许Hibernate与J2EE服务器集成。

Hibernate应用结构体系主要类对象

Configuration Object

Configuration Object是我们在Hibernate应用程序中创建的第一个Hibernate对象,通常在应用程序初始化时且只创建一次。它是Hibernate所需要的配置和属性文件。Configuration对象提供两个关键组件:

  • Database Connection:通过Hibernate支持的一个或多个配置文件来处理。hibernate.properties,hibernate.cfg.xml
  • Class Mapping Setup:这个组件用于Java类和数据库表之间创建连接。

SessionFactory Object

Configuration Object用于创建一个SessionFactory Obejct,该对象使用提供的配置文件为应用程序配置Hibernate,并允许实例化一个Session对象。SessionFactory线程安全对象,供应用程序的所有线程使用。

SessionFactory是重量级对象。因此通常在应用程序启动期间创建并保留供以后使用。

每个数据库都需要使用一个单独的配置文件创建一个SessionFactory对象。如果使用多个数据库,则必须创建多个SessionFactory对象。

Session(会话) Object

Session(会话)用于获取与数据库的物理连接,Session对象是轻量级的,并且是每当需要与数据库进行交互时才会被实例化。持久化对象通过Session对象进行保存和检索。

Session对象不应该长时间保持打开,因为他们通常不是线程安全的,所以应该根据业务需求创建和销毁它们。

Transaction(事务) Object

事务Transaction代表与数据库的工作单元,大多数关系型数据库都支持事务功能。Hibernate中的事务由底层事务管理器和事务(来自JDBC和JTA)处理。

这是一个可选对象,Hibernate应用程序可以选择不使用此接口,而选择在自己的应用程序代码中管理事务。

Query Object

查询Query对象使用SQL或者Hibernate查询语言(Hibernate Query Language,HQL)字符串从数据库检索数据并创建对象。Query实例用于绑定查询参数,限制查询返回的结果数量,最后执行查询。

Criteria Object

条件对象用于创建和执行面向对象的标准查询以检索对象。

Hibernate 环境配置

该章主要介绍如何安装Hibernate以及其它相关包来为Hibernate应用程序准备一个开发环境。本文将使用Mysql数据库来演示Hibernate实例。

Hibernate下载

  • 在windows上下载.zip文件,在Unix上下载.tz文件。
  • 从http://www.hibernate.org/downloads下载最新版的Hibernate。
  • 下载完成之后进行解压。

安装Hibernate

下载完Hibernate之后,只需要执行以下两个简单的步骤即可。请确保正确的配置了CLASSPATH环境变量,否则在编译应用程序时会出现问题。

Hibernate的依赖包

S.N.Packages/Libraries
1dom4j – XML parsing www.dom4j.org/
2Xalan – XSLT Processor http://xml.apache.org/xalan-j/
3Xerces – The Xerces Java Parser http://xml.apache.org/xerces-j/
4cglib – Appropriate changes to Java classes at runtime http://cglib.sourceforge.net/
5log4j – Logging Faremwork http://logging.apache.org/log4j
6Commons – Logging, Email etc. http://jakarta.apache.org/commons
7SLF4J – Logging Facade for Java http://www.slf4j.org

Hibernate配置

Hibernate需要提前知道在哪里可以找到定义的Java类和数据库表相关联的映射信息。Hibernate还需要一组与数据库和其它相关参数相关的配置设置。所有这些信息通常作为标准java属性文件hibernate.properties或者名为hibernate.cfg.xml的XML文件提供。

Hibernate属性

以下是在独立情况下为一个数据库配置所需要的重要属性列表:

S.N.Properties and Description
1 hibernate.dialect:此属性使Hibernate为选定的数据库生成适当的SQL
2 hibernate.connection.driver_class:JDBC驱动程序类
3 hibernate.connection.url:数据库实例的JDBC URL
4 hibernate.connection.username:数据库用户名
5 hibernate.connection.password:数据库密码
6 hibernate.connection.pool_size:限制在Hibernate数据库连接池中的等待连接数
7 hibernate.connection.autocommit:允许JDBC连接自动提交

如果随着应用服务器和JNDI使用同一个服务器,则还需要配置以下属性:

S.N.Properties and Description
1 hibernate.connection.datasource:在应用服务器中定义的JNDI名称
2 hibernate.jndi.class:JNDI的InitialContext类
3 hibernate.jndi.:
4 hibernate.jndi.url:提供JNDI的url
5 hibernate.connection.username:数据库用户名
6 hibernate.connection.password:数据库密码

Hibernate和Mysql数据库

MySQL是目前最流行的开源数据库系统之一,下面我们创建一个hibernate.cfg.xml配置文件,并将其放置于应用程序类路径的根目录下,必须确保已经安装MySQL 并保证已经保证创建了可用的测试数据库。
XML配置文件必须符合Hibernate 3 Configuration DTD,该文件可从http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd获得。


"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">



org.hibernate.dialect.MySQLDialect


com.mysql.jdbc.Driver



jdbc:mysql://localhost/test


root


root123





下表是各类数据库的属性类型(Dialect Property)列表:

DatabaseDialect Property
DB2org.hibernate.dialect.DB2Dialect
HSQLDBorg.hibernate.dialect.HSQLDialect
HypersonicSQLorg.hibernate.dialect.HSQLDialect
Informixorg.hibernate.dialect.InformixDialect
Ingresorg.hibernate.dialect.IngresDialect
Interbaseorg.hibernate.dialect.InterbaseDialect
Microsoft SQL Server 2000org.hibernate.dialect.SQLServerDialect
Microsoft SQL Server 2005org.hibernate.dialect.SQLServer2005Dialect
Microsoft SQL Server 2008org.hibernate.dialect.SQLServer2008Dialect
MySQLorg.hibernate.dialect.MySQLDialect
Oracle (any version)org.hibernate.dialect.OracleDialect
Oracle 11gorg.hibernate.dialect.Oracle10gDialect
Oracle 10gorg.hibernate.dialect.Oracle10gDialect
Oracle 9iorg.hibernate.dialect.Oracle9iDialect
PostgreSQLorg.hibernate.dialect.PostgreSQLDialect
Progressorg.hibernate.dialect.ProgressDialect
SAP DBorg.hibernate.dialect.SAPDBDialect
Sybaseorg.hibernate.dialect.SybaseDialect
Sybase Anywhereorg.hibernate.dialect.SybaseAnywhereDialect

Hibernate实例

创建POJO类

  • 首先,我们创建Java POJO类,这取决于将被持久化到数据库的应用程序,生成getXXX()setXXX()方法,使其成为JavaBeans兼容类。
  • POJO(java普通对象)是一种java对象,它不扩展或实现一些EJB框架分别需要的一些专门的类或接口。所有正常的Java对象都是POJO。
  • 当你设计一个要被Hibernate持久化的类时,提供符合JavaBeans的代码以及一个在Employee类中像id属性一样用作索引的属性很重要。

public class Employee {
private int id;
private String firstName;
private String lastName;
private int salary;
public Employee() {}
public Employee(String fname, String lname, int salary) {
this.firstName = fname;
this.lastName = lname;
this.salary = salary;
}
public int getId() {
return id;
}
public void setId( int id ) {
this.id = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName( String first_name ) {
this.firstName = first_name;
}
public String getLastName() {
return lastName;
}
public void setLastName( String last_name ) {
this.lastName = last_name;
}
public int getSalary() {
return salary;
}
public void setSalary( int salary ) {
this.salary = salary;
}
}

创建数据库表

第二步,我们需要在数据库中创建一张表,将表对应我们需要持久化的每一个对象,根据上面的java类我们创建下面这样一个表“

create table EMPLOYEE (
id INT NOT NULL auto_increment,
first_name VARCHAR(20) default NULL,
last_name VARCHAR(20) default NULL,
salary INT default NULL,
PRIMARY KEY (id)
);

创建配置映射文件

接下来我们需要创建一个配置文件,说明Hibernate如何将定义的类映射至数据库表。


"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">



This class contains the employee detail.









我们应该把映射文件保存为.hbm.xml格式的文件。上面文件保存为Employee.hbm.xml

  • 映射文件是一个XML格式的文档。作为包含所有元素的根元素。
  • 元素用于定义从java类到数据库表的特定映射。java类名称使用使用类元素的name属性指定,并且使用table属性指定数据库表名称。
  • 元素是可选元素,用于创建类描述。
  • 是将类中的唯一ID元素映射到数据库表的主键。id元素中的name属性引用类中的属性,cloumn属性引用数据库表中的列。type属性保存hibernate映射类型,此映射类型将从Java转换成SQL数据类型。
  • id元素中的属性用于自动生成主键值,设置class的属性值为native,让hibernate选择identitysequence,hilo算法来创建主键,这取决于底层数据库的能力。
  • 元素用于将Java类属性映射到数据库表中的列。元素的name属性引用类中的属性,cloumn属性引用数据库表中的列。type属性保存hibernate映射类型,此映射类型将从Java类型转换成SQL数据类型。

创建应用类(java class)

完成了以上步骤后,我们来创建一个应用文件来测试一下我们的配置。

import java.util.List;
import java.util.Date;
import java.util.Iterator;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class ManageEmployee {
private static SessionFactory factory;
public static void main(String[] args) {
try{
factory = new Configuration().configure().buildSessionFactory();
}catch (Throwable ex) {
System.err.println("Failed to create sessionFactory object." + ex);
throw new ExceptionInInitializerError(ex);
}
ManageEmployee ME = new ManageEmployee();
/* 添加一些employee对象到数据库表中*/
Integer empID1 = ME.addEmployee("Zara", "Ali", 1000);
Integer empID2 = ME.addEmployee("Daisy", "Das", 5000);
Integer empID3 = ME.addEmployee("John", "Paul", 10000);
/* 列出所有employee对象 */
ME.listEmployees();
/* 修改 */
ME.updateEmployee(empID1, 5000);
/* 从数据库中删除 */
ME.deleteEmployee(empID2);
/* 列出所有对象s */
ME.listEmployees();
}
/* 向数据库中添加employee对象的方法 */
public Integer addEmployee(String fname, String lname, int salary){
Session session = factory.openSession();
Transaction tx = null;
Integer employeeID = null;
try{
tx = session.beginTransaction();
Employee employee = new Employee(fname, lname, salary);
employeeID = (Integer) session.save(employee);
tx.commit();
}catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
}finally {
session.close();
}
return employeeID;
}
/* 列出所有employee对象的方法 */
public void listEmployees( ){
Session session = factory.openSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
List employees = session.createQuery("FROM Employee").list();
for (Iterator iterator =
employees.iterator(); iterator.hasNext();){
Employee employee = (Employee) iterator.next();
System.out.print("First Name: " + employee.getFirstName());
System.out.print(" Last Name: " + employee.getLastName());
System.out.println(" Salary: " + employee.getSalary());
}
tx.commit();
}catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
}finally {
session.close();
}
}
/* 修改employee对象的方法 */
public void updateEmployee(Integer EmployeeID, int salary ){
Session session = factory.openSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
Employee employee =
(Employee)session.get(Employee.class, EmployeeID);
employee.setSalary( salary );
session.update(employee);
tx.commit();
}catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
}finally {
session.close();
}
}
/* 删除employee对象的方法 */
public void deleteEmployee(Integer EmployeeID){
Session session = factory.openSession();
Transaction tx = null;
try{
tx = session.beginTransaction();
Employee employee =
(Employee)session.get(Employee.class, EmployeeID);
session.delete(employee);
tx.commit();
}catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
}finally {
session.close();
}
}
}

编译和执行

编译和执行的步骤(请确保正确配置了环境变量):

  • 创建hibernate.cfg.xml配置文件。
  • 创建Employee.hbm.xml映射文件。
  • 创建Employee.java文件,并编译它。
  • 创建如上所示的ManageEmployee.java文件,并执行编译。
  • 执行ManageEmployee.class文件,运行程序。

推荐阅读
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了如何使用Power Design(PD)和SQL Server进行数据库反向工程的方法。通过创建数据源、选择要反向工程的数据表,PD可以生成物理模型,进而生成所需的概念模型。该方法适用于SQL Server数据库,对于其他数据库是否适用尚不确定。详细步骤和操作说明可参考本文内容。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
author-avatar
奔三人2502933897
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有