站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
▼
建站程序
开发
服务器
办公软件
开发教程
▼
服务器教程
软件使用教程
运营教程
热门电子书
▼
CSS教程
WordPress教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
热点词条
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
Hibernate
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
[[Image:Hibernate.jpg|right]] '''Hibernate'''是一种[[Java]]语言下的对象关系映射解决方案。 它是使用[[GNU]]宽通用公共许可证发行的自由、[[开源]]的[[软件]]。它为[[面向对象]]的领域模型到传统的关系型数据库的映射,提供了一个使用方便的[[框架]]。 Hibernate对[[JDBC]]进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵[[数据库]]。Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在[[Servlet]]/[[JSP]]的[[Web]]应用中使用,最具革命意义的是,Hibernate可以在应用[[EJB]]的[[J2EE]]架构中取代CMP,完成数据持久化的重任。 ==简介== 大多数[[应用程序]]都需要处理[[数据]]。Java应用程序运行时,往往把数据封装为相互连接的对象[[网络]],但是当程序结束时,这些对象就会消失在一团逻辑中,所以需要有一些保存它们的方法。有时候,甚至在编写应用程序之前,数据就已经存在了,所以需要有读入它们和将其表示为对象的方法。手动编写[[代码]]来执行这些任务不仅单调乏味、易于出错,而且会占用整个应用程序的很大一部分开发工作量。 优秀的面向对象开发人员厌倦了这种重复性的劳动,他们开始采用通常的“积极”偷懒做法,即创建工具,使整个过程自动化。对于关系数据库来说,这种努力的最大成果就是对象/关系映射(ORM)工具。 这类工具有很多,从昂贵的商业产品到内置于J2EE中的EJB标准。然而,在很多情况下,这些工具具有自身的复杂性,使得开发人员必须学习使用它们的详细规则,并修改组成应用程序的类以满足映射系统的需要。由于这些工具为应付更加严格和复杂的企业需求而不断发展,于是在比较简单和常见的场景中,使用它们所面临的复杂性反而盖过了所能获得的好处。这引起了一场革命,促进了轻量级解决方案的出现,而Hibernate就是这样的一个例子。 ==核心接口== Hibernate的核心接口一共有5个,分别为:Session、SessionFactory、Transaction、Query和Configuration。这5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。下面对这五个核心接口分别加以介绍。 ===Session接口=== Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的[[SQL]]语句。)。但需要注意的是Session对象是非[[线程]]安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。 ===SessionFactory接口=== SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。 ===Configuration接口=== Configuration接口负责配置并启动Hibernate,创建SessionFactory对象。在Hibernate的启动的过程中,Configuration类的实例首先定位映射文档位置、读取配置,然后创建SessionFactory对象。 ===Transaction接口=== Transaction接口负责事务相关的操作。它是可选的,开发人员也可以设计编写自己的底层事务处理代码。 ===Query和Criteria接口=== Query和Criteria接口负责执行各种数据库查询。它可以使用[[HQL]]语言或SQL语句两种表达方式。 ==Hibernate主键介绍== ===Assigned=== Assigned方式由用户生成主键值,并且要在save()之前指定否则会抛出异常 特点:主键的生成值完全由用户决定,与底层数据库无关。用户需要维护主键值,在调用session.save()之前要指定主键值。 ===Hilo=== Hilo使用高低位算法生成主键,高低位算法使用一个高位值和一个低位值,然后把算法得到的两个值拼接起来作为数据库中的唯一主键。Hilo方式需要额外的数据库表和字段提供高位值来源。默认请况下使用的表是'''hibernate_unique_key''',默认字段叫作'''next_hi'''。next_hi必须有一条记录否则会出现错误。 特点:需要额外的数据库表的支持,能保证同一个数据库中主键的唯一性,但不能保证多个数据库之间主键的唯一性。Hilo主键生成方式由Hibernate 维护,所以Hilo方式与底层数据库无关,但不应该手动修改hi/lo算法使用的表的值,否则会引起主键重复的异常。 ===Increment=== Increment方式对主键值采取自动增长的方式生成新的主键值,但要求底层数据库的支持[[Sequence]]。如[[Oracle]],[[DB2]]等。需要在映射文件xxx.hbm.xml中加入Increment标志符的设置。 特点:由Hibernate本身维护,适用于所有的数据库,不适合多[[进程]]并发更新数据库,适合单一进程访问数据库。不能用于群集环境。 ===Identity=== Identity当时根据底层数据库,来支持自动增长,不同的数据库用不同的主键增长方式。 特点:与底层数据库有关,要求数据库支持Identity,如[[MySQL]]中是auto_increment, [[SQL Server]] 中是Identity,支持的数据库有MySql、SQL Server、DB2、[[Sybase]]和''HypersonicSQL''。 Identity无需Hibernate和用户的干涉,使用较为方便,但不便于在不同的数据库之间移植程序。 ===Sequence=== Sequence需要底层数据库支持Sequence方式,例如Oracle数据库等 特点:需要底层数据库的支持序列,支持序列的数据库有DB2、[[PostgreSql]]、Oracle、[[SAPDb]]等在不同数据库之间移植程序,特别从支持序列的数据库移植到不支持序列的数据库需要修改配置文件 ===Native=== Native主键生成方式会根据不同的底层数据库自动选择Identity、Sequence、Hilo主键生成方式 特点:根据不同的底层数据库采用不同的主键生成方式。由于Hibernate会根据底层数据库采用不同的映射方式,因此便于程序移植,项目中如果用到多个数据库时,可以使用这种方式。 ===UUID=== UUID使用128位UUID算法生成主键,能够保证[[网络]]环境下的主键唯一性,也就能够保证在不同数据库及不同服务器下主键的唯一性。 特点;能够保证数据库中的主键唯一性,生成的主键占用比较多的存贮空间 ===Foreign GUID=== Foreign用于一对一关系中。GUID主键生成方式使用了一种特殊算法,保证生成主键的唯一性,支持SQL Server和MySQL ==Hibernate源码对照== [[Image:Hibernate source.gif|right]] *net.sf.hibernate.* :该包的类基本上都是接口类和异常类 *net.sf.hibernate.cache.* :[[JCS]]的实现类 *net.sf.hibernate.cfg.* :配置文件读取类 *net.sf.hibernate.collection.* :Hibernate集合接口实现类,例如List,Set,Bag等等,Hibernate之所以要自行编写集合接口实现类是为了支持lazy loading *net.sf.hibernate.connection.* :几个数据库连接池的Provider *net.sf.hibernate.dialect.* :支持多种数据库特性,每个Dialect实现类代表一种数据库,描述了该数据库支持的数据类型和其它特点,例如是否有AutoIncrement,是否有Sequence,是否有分页sql等等 *net.sf.hibernate. eg.* :Hibernate文档中用到的例子 *net.sf.hibernate.engine.* :这个包的类作用比较散 *net.sf.hibernate.expression.* :HQL支持的表达式 *net.sf.hibernate.hq.* :HQL实现 *net.sf.hibernate. id.* :ID生成器 *net.sf.hibernate.impl.* :最核心的包,一些重要接口的实现类,如果[[Session]],SessionFactory,[[Query]]等 *net.sf.hibernate.jca.* :[[JCA]]支持,把Session包装为支持JCA的接口实现类 *net.sf.hibernate.jmx.* :[[JMX]]是用来编写App Server的管理程序的,使得App Server可以通过JMX接口管理Hibernate *net.sf.hibernate.loader.* :也是很核心的包,主要是生成sql语句的 *net.sf.hibernate.lob.* :Blob和Clob支持 *net.sf.hibernate.mapping.* :hbm文件的属性实现 *net.sf.hibernate.metadata.* :PO的Meta实现 *net.sf.hibernate.odmg.* :ODMG是一个ORM标准,这个包是ODMG标准的实现类 *net.sf.hibernate.persister.* :核心包,实现持久对象和表之间的映射 *net.sf.hibernate.proxy.* :Proxy和Lazy Loading支持 *net.sf.hibernate. ps.* :该包是PreparedStatment Cache *net.sf.hibernate.sql.* :生成JDBC sql语句的包 *net.sf.hibernate.test.* :测试类,你可以用junit来测试Hibernate *net.sf.hibernate.tool.hbm2ddl.* :用hbm配置文件生成[[DDL]] *net.sf.hibernate.transaction.* :Hibernate Transaction实现[[类]] *net.sf.hibernate.type.* :Hibernate中定义的持久对象的属性的数据类型 *net.sf.hibernate.util.* :一些工具类,作用比较散 *net.sf.hibernate.xml.* :[[XML]]数据绑定 ==相关条目== *[[Spring]] *[[JSF]] *[[Struts]] *[[HQL]] ==参考来源== *http://www.hudong.com/wiki/hibernate *http://baike.baidu.com/view/7291.htm *http://zh.wikipedia.org/wiki/Hibernate [[category:J2EE|H]] [[category:框架|H]] [[category:开放源代码|H]] [[category:Hibernate|H]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)