我的日常

登录/注册
您现在的位置:论坛 盖世程序员(我猜到了开头 却没有猜到结局) 盖世程序员 > 如何快速学好SSH三大框架做好web开发
总共48086条微博

动态微博

查看: 9907|回复: 16

如何快速学好SSH三大框架做好web开发

[复制链接]

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

跳转到指定楼层
#
发表于 2014-03-11 21:43:11 |只看该作者 |正序浏览
一、三大框架简介
1spring
Spring是一个解决了许多在J2EE开发中常见的问题的强大框架。Spring提供了管理业务对象的一致方法并且鼓励了注入对接口编程而不是对类编程的良好习惯。Spring的架构基础是基于使用javaBean属性的Inversion of Control容器。然而,这仅仅是完整图景中的一部分:Spring在使用IoC容器作为构建完关注所有架构层的完整解决方案方面是独一无二的。 Spring提供了唯一的数据访问抽象,包括简单和有效率的JDBC框架,极大的改进了效率并且减少了可能的错误。Spring的数据访问架构还集成了hibernate和其他O/R mapping解决方案。Spring还提供了唯一的事务管理抽象,它能够在各种底层事务管理技术,例如JTA或者JDBC事务提供一个一致的编程模型。Spring提供了一个用标准Java语言编写的AOP框架,它给POJOs提供了声明式的事务管理和其他企业事务--如果你需要--还能实现你自己的aspects。这个框架足够强大,使得应用程序能够抛开EJB的复杂性,同时享受着和传统EJB相关的关键服务。Spring还提供了可以和IoC容器集成的强大而灵活的MVC Web框架。
2STRUCTS
struts是一个基于Sun J2EE平台的MVC框架,主要是采用ServletJSP技术来实现的。由于Struts能充分满足应用开发的需求,简单易用,敏捷迅速,在过去的一年中颇受关注。StrutsServletJSP、自定义标签和信息资源(message resources)整合到一个统一的框架中,开发人员利用其进行开发时不用再自己编码实现全套MVC模式,极大的节省了时间,所以说Struts是一个非常不错的应用框架。
3Hibernate
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序实用,也可以在Servlet/JSPWeb应用中使用,最具革命意义的是,Hibernate可以在应用EJBJ2EE架构中取代CMP,完成数据持久化的重任。,Hibernate可以在应用EJBJ2EE架构中取代CMP,完成数据持久化的重任。
JAVA三大框架用来做WEB应用。
struts主要负责表示层的显示
spring利用它的IOCAOP来处理控制业务(负责对数据库的操作)
hibernate主要是数据的持久化到数据库
在用jspservlet做网页开发的时候有个web.xml的映射文件,里面有个mapping的标签就是用来做文件映射的。
当你在浏览器上输入URL地址的时候,文件就会根据你写的名称对应到一个java文件,根据java文件里编写的内容显示在浏览器上,就是一个网页,所以网页名字是随便写的,随便起的名字,不管你起的是.php .jsp .do还是其他的什么都对应这个java文件,这个java文件里的代码进行什么操作就干什么,显示一句话还是连接数据库还是跳转到其他页面等等,这个java文件把数据进行封装起到安全和便于管理的作用。其实这个java文件编译过来是.class的一个字节码文件,没有那么一个类似html嵌入标签和代码的网页文件。他与jsp文件区别就是jsp把代码嵌入到html标签中。
3 L& h5 T9 B% h% ~3 Q' z( z; f

科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、科帮网管理员和版主有权不事先通知发贴者而删除本文


JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

12

主题

3

听众

526

金钱

四袋长老

该用户从未签到

16#
发表于 2016-04-18 17:04:47 |只看该作者
可以的,不过内容感觉挺长
回复

使用道具 举报

11

主题

1

听众

271

金钱

三袋弟子

该用户从未签到

15#
发表于 2016-04-07 11:58:55 |只看该作者
好多知识,独特的见解,研究研究
回复

使用道具 举报

13

主题

9

听众

4517

金钱

八袋长老

该用户从未签到

14#
发表于 2016-03-18 14:28:55 |只看该作者
发的什么东西哦。。。。
回复

使用道具 举报

3

主题

0

听众

212

金钱

四袋长老

该用户从未签到

13#
发表于 2016-03-07 17:46:24 |只看该作者
很不错哟,谢谢楼主,受教了。
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

12#
发表于 2014-03-11 21:44:59 |只看该作者
虑的步骤。   2) 选择合适的缓存插件,然后编辑该插件的配置文件。+ t0 z" U/ J4 q: d& _
编辑本段Hibernate与延迟加载- g% x% y$ I: N: M) M- A8 u
  Hibernate对象关系映射提供延迟的与非延迟的对象初始化。非延迟加载在读取一个对象的时候会将与这个对象所有相关的其他对象一起读取出来。这有时会导致成百的(如果不是成千的话)select语句在读取对象的时候执行。这个问题有时出现在使用双向关系的时候,经常会导致整个数据库都在初始化的阶段被读出来了。当然,你可以不厌其烦地检查每一个对象与其他对象的关系,并把那些最昂贵的删除,但是到最后,我们可能会因此失去了本想在ORM工具中获得的便利。   一个明显的解决方法是使用Hibernate提供的延迟加载机制。这种初始化策略只在一个对象调用它的一对多或多对多关系时才将关系对象读取出来。这个过程对开发者来说是透明的,而且只进行了很少的数据库操作请求,因此会得到比较明显的性能提升。这项技术的一个缺陷是延迟加载技术要求一个Hibernate会话要在对象使用的时候一直开着。这会成为通过使用DAO模式将持久层抽象出来时的一个主要问题。为了将持久化机制完全地抽象出来,所有的数据库逻辑,包括打开或关闭会话,都不能在应用层出现。最常见的是,一些实现了简单接口的DAO实现类将数据库逻辑完全封装起来了。一种快速但是笨拙的解决方法是放弃DAO模式,将数据库连接逻辑加到应用层中来。这可能对一些小的应用程序有效,但是在大的系统中,这是一个严重的设计缺陷,妨碍了系统的可扩展性。+ c0 j7 y4 ^# k2 _2 Z) {
编辑本段在Web层进行延迟加载6 H$ W3 ?" N  g6 ?- A. d+ L' o
  幸运的是,Spring框架为Hibernate延迟加载与DAO模式的整合提供了一种方便的解决方法。以一个Web应用为例,Spring提供了OpenSessionInViewFilter和OpenSessionInViewInterceptor。我们可以随意选择一个类来实现相同的功能。两种方法唯一的不同就在于interceptor在Spring容器中运行并被配置在web应用的上下文中,而Filter在Spring之前运行并被配置在web.xml中。不管用哪个,他们都在请求将当前会话与当前(数据库)线程绑定时打开Hibernate会话。一旦已绑定到线程,这个打开了的Hibernate会话可以在DAO实现类中透明地使用。这个会话会为延迟加载数据库中值对象的视图保持打开状态。一旦这个逻辑视图完成了,Hibernate会话会在Filter的doFilter方法或者Interceptor的postHandle方法中被关闭。   实现方法在web.xml中加入   <filter>   <filter-name>hibernateFilter</filter-name>   <filter-class>   org.springframework.orm.hibernate3.support.OpenSessionInViewFilter   </filter-class>   </filter   <filter-mapping>   <filter-name>hibernateFilter</filter-name>   <url-pattern>*.do</url-pattern>   </filter-mapping>
$ v5 d+ l" t4 Q5 p# r9 X9 \3 e- t) v( b4 r5 ^8 F" v

( f, G) u" b3 o5 h, a- X# v9 Y  i7 t1 G" Z7 \5 t2 G
五、学习顺序和条件) T5 l# Q6 L+ G$ O7 l- |$ m& V
一步一步的学,要学三个框架(struts + hibernate +spring),建议,先学懂以下技术6 R5 U7 S4 n* q- K  e( _9 ~
1、J2SE 必须的,有点废话 - -
; U& Y; i2 U% o5 y" h. {2、数据库(Oracle,MySql...)
- k* w) j( z& ]9 W7 e+ F( a! f0 k0 |3、JDBC' H+ G# t# g- k4 w5 ~. u) F' h
4、jsp + servlet  V; i% T! v  r" r/ X% x1 A/ V6 @
然后先学struts,接着学hibernate,再学spring。& O1 g7 M5 e2 T, S% {: {  Q) {% |
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

11#
发表于 2014-03-11 21:44:51 |只看该作者
evict(Object obj):从缓存中清除参数指定的持久化对象。 clear():清空缓存中所有持久化对象。
. W. d) I8 m! F9 _5 j) M/ v9 ~二级缓存的管理
( I0 A1 {' j5 ^0 z  3.1. Hibernate的二级缓存策略的一般过程如下:   1) 条件查询的时候,总是发出一条select * from table_name where …. (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象。   2) 把获得的所有数据对象根据ID放入到第二级缓存中。   3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查;查不到,如果配置了二级缓存,那么从二级缓存中查;查不到,再查询数据库,把结果按照ID放入到缓存。   4) 删除、更新、增加数据的时候,同时更新缓存。   Hibernate的二级缓存策略,是针对于ID查询的缓存策略,对于条件查询则毫无作用。为此,Hibernate提供了针对条件查询的Query Cache。   3.2. 什么样的数据适合存放到第二级缓存中? 1 很少被修改的数据 2 不是很重要的数据,允许出现偶尔并发的数据 3 不会被并发访问的数据 4 参考数据,指的是供应用参考的常量数据,它的实例数目有限,它的实例会被许多其他类的实例引用,实例极少或者从来不会被修改。   3.3. 不适合存放到第二级缓存的数据? 1 经常被修改的数据 2 财务数据,绝对不允许出现并发 3 与其他应用共享的数据。   3.4. 常用的缓存插件 Hibernater 的二级缓存是一个插件,下面是几种常用的缓存插件:   l EhCache:可作为进程范围的缓存,存放数据的物理介质可以是内存或硬盘,对Hibernate的查询缓存提供了支持。   l OSCache:可作为进程范围的缓存,存放数据的物理介质可以是内存或硬盘,提供了丰富的缓存数据过期策略,对Hibernate的查询缓存提供了支持。   l SwarmCache:可作为群集范围内的缓存,但不支持Hibernate的查询缓存。   l JBossCache:可作为群集范围内的缓存,支持事务型并发访问策略,对Hibernate的查询缓存提供了支持。   上述4种缓存插件的对比情况列于表9-3中。   表9-3 4种缓存插件的对比情况   缓 存 插 件 支 持 只 读 支持非严格读写 支 持 读 写 支 持 事 务 ( q( b: u2 z' E( U; O
EhCache 是 是 是
% t' b2 T$ Q& X% P" I- ]0 L/ J 1 T. G  {/ h5 R8 t7 e" O- O% X
OSCache 是 是 是 & J( m  R+ M4 {9 @  E

$ p1 @  \+ j0 d' E$ w% b5 Q& v$ tSwarmCache 是 是 2 z' c, u5 F3 @3 [; _2 D
3 n- O' G* y3 V  R8 o, L

  u* a: o- `  ~, i& ZJBossCache 是
" n' C4 H  ~& L+ z  U
, r+ l7 ]5 W; G4 }; d! j) {# w9 R' _; v8 a4 s) C9 m! i# U  q7 m7 ]& n: E
它们的提供器列于表9-4中。   表9-4 缓存策略的提供器   缓 存 插 件 提供器(Cache Providers) % D0 f: r9 d$ c: L2 H, R2 N7 S4 G
Hashtable(只能测试时使用) org.hibernate.cache.HashtableCacheProvider ' M8 r. k- Q; C9 ^" b7 l) Q
EhCache org.hibernate.cache.EhCacheProvider
6 t, f0 \) v! V$ tOSCache org.hibernate.cache.OSCacheProvider - u$ ^* S$ a. V0 m7 v
SwarmCache org.hibernate.cache.SwarmCacheProvider
$ h, O2 P; [* s& DJBossCache org.hibernate.cache.TreeCacheProvider ! y2 i  e) j# _7 u- r
在默认情况下,Hibernate使用EhCache进行JVM级别的缓存。用户可以通过设置Hibernate配置文件中的hibernate.cache.provider_class的属性,指定其他的缓存策略,该缓存策略必须实现org.hibernate.cache.CacheProvider接口。   3.5. 配置二级缓存的主要步骤:   1) 选择需要使用二级缓存的持久化类,设置它的命名缓存的并发访问策略。这是最值得认真考
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

10#
发表于 2014-03-11 21:44:42 |只看该作者
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数据绑定
1 T, F6 F) A  @编辑本段缓存管理
" ^' \% v3 q1 R# u4 ]& V1 D  Hibernate 中提供了两级Cache,第一级别的缓存是Session级别的缓存,它是属于事务范围的缓存。这一级别的缓存由hibernate管理的,一般情况下无需进行干预;第二级别的缓存是SessionFactory级别的缓存,它是属于进程范围或群集范围的缓存。这一级别的缓存可以进行配置和更改,并且可以动态加载和卸载。 Hibernate还为查询结果提供了一个查询缓存,它依赖于第二级缓存。
! y4 \0 L3 d. Q) |/ i一级缓存和二级缓存的比较' a# W# z) Y% ]/ ~+ {
  第一级缓存 第二级缓存 存放数据的形式 相互关联的持久化对象 对象的散装数据 缓存的范围 事务范围,每个事务都有单独的第一级缓存进程范围或集群范围,缓存被同一个进程或集群范围内的所有事务共享 并发访问策略由于每个事务都拥有单独的第一级缓存,不会出现并发问题,无需提供并发访问策略由于多个事务会同时访问第二级缓存中相同数据,因此必须提供适当的并发访问策略,来保证特定的事务隔离级别 数据过期策略没有提供数据过期策略。处于一级缓存中的对象永远不会过期,除非应用程序显式清空缓存或者清除特定的对象必须提供数据过期策略,如基于内存的缓存中的对象的最大数目,允许对象处于缓存中的最长时间,以及允许对象处于缓存中的最长空闲时间 物理存储介质内存内存和硬盘。对象的散装数据首先存放在基于内存的缓存中,当内存中对象的数目达到数据过期策略中指定上限时,就会把其余的对象写入基于硬盘的缓存中。缓存的软件实现 在Hibernate的Session的实现中包含了缓存的实现由第三方提供,Hibernate仅提供了缓存适配器(CacheProvider)。用于把特定的缓存插件集成到Hibernate中。启用缓存的方式只要应用程序通过Session接口来执行保存、更新、删除、加载和查询数据库数据的操作,Hibernate就会启用第一级缓存,把数据库中的数据以对象的形式拷贝到缓存中,对于批量更新和批量删除操作,如果不希望启用第一级缓存,可以绕过Hibernate API,直接通过JDBC API来执行指操作。用户可以在单个类或类的单个集合的粒度上配置第二级缓存。如果类的实例被经常读但很少被修改,就可以考虑使用第二级缓存。只有为某个类或集合配置了第二级缓存,Hibernate在运行时才会把它的实例加入到第二级缓存中。 用户管理缓存的方式第一级缓存的物理介质为内存,由于内存容量有限,必须通过恰当的检索策略和检索方式来限制加载对象的数目。Session的evit()方法可以显式清空缓存中特定对象,但这种方法不值得推荐。 第二级缓存的物理介质可以是内存和硬盘,因此第二级缓存可以存放大量的数据,数据过期策略的maxElementsInMemory属性值可以控制内存中的对象数目。管理第二级缓存主要包括两个方面:选择需要使用第二级缓存的持久类,设置合适的并发访问策略:选择缓存适配器,设置合适的数据过期策略。
) `2 _7 @2 O+ T* r一级缓存的管理
; S+ C$ P! |3 d' L) C* x' a) A  当应用程序调用Session的save()、update()、saveOrUpdate()、get()或load(),以及调用查询接口的 list()、iterate()或filter()方法时,如果在Session缓存中还不存在相应的对象,Hibernate就会把该对象加入到第一级缓存中。当清理缓存时,Hibernate会根据缓存中对象的状态变化来同步更新数据库。 Session为应用程序提供了两个管理缓存的方法:
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

9#
发表于 2014-03-11 21:44:33 |只看该作者
据库,适合单一进程访问数据库。不能用于群集环境。# t0 Q1 r( _" r
Identity
- }& }) h9 y8 ^+ |2 S  y  Identity当时根据底层数据库,来支持自动增长,不同的数据库用不同的主  Hibernate相关书籍
+ r, |: k- e2 @  F键增长方式。   特点:与底层数据库有关,要求数据库支持Identity,如MySQl中是auto_increment, SQL Server 中是Identity,支持的数据库有MySql、SQL Server、DB2、Sybase和HypersonicSQL。 Identity无需Hibernate和用户的干涉,使用较为方便,但不便于在不同的数据库之间移植程序。
9 p9 W* M; q9 a/ CSequence
  T5 N* P$ |3 s1 z7 @  Sequence需要底层数据库支持Sequence方式,例如Oracle数据库等   特点:需要底层数据库的支持序列,支持序列的数据库有DB2、PostgreSql、Oracle、SAPDb等在不同数据库之间移植程序,特别从支持序列的数据库移植到不支持序列的数据库需要修改配置文件
; B8 k. ^4 T1 m# @( ONative  }" r! K2 ?8 ]( e: \& q
  Native主键生成方式会根据不同的底层数据库自动选择Identity、Sequence、Hilo主键生成方式   特点:根据不同的底层数据库采用不同的主键生成方式。由于Hibernate会根据底层数据库采用不同的映射方式,因此便于程序移植,项目中如果用到多个数据库时,可以使用这种方式。
3 W2 L9 i, r- ~% z' e2 KUUID- K; M* y# w( p8 f! ^
  UUID使用128位UUID算法生成主键,能够保证网络环境下的主键唯一性,也就能够保证在不同数据库及不同服务器下主键的唯一性。   特点;能够保证数据库中的主键唯一性,生成的主键占用比较多的存贮空间
/ G# ~6 J) n& R* o4 mForeign GUID
" z1 X6 I, Y  ~: C! J  Foreign用于一对一关系中。GUID主键生成方式使用了一种特殊算法,保证生成主键的唯一性,支持SQL Server和MySQL
+ d. k- h+ S9 N+ M& c" b5 i: m编辑本段Hibernate源码中几个包的作用简要介绍
/ p/ \& b( _/ W1 E  J  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,只知道JMX是用来编写App Server的管理程序的,大概是JMX部分接口的实现,使得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标准,这个包是
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

8#
发表于 2014-03-11 21:44:16 |只看该作者
SessionFactory接口
3 Z" {$ t$ @# j$ ~5 }' k' w  SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。0 A. K8 v! z6 Q- Z, o# R
Configuration接口
# Z5 y; }! B* M  Configuration接口负责配置并启动Hibernate,创建SessionFactory对象。在Hibernate的启动的过程中,Configuration类的实例首先定位映射文档位置、读取配置,然后创建SessionFactory对象。9 v2 t  `0 d  A) a
Transaction接口1 G; f2 x% p  x6 a3 K
  Transaction接口负责事务相关的操作。它是可选的,开发人员也可以设计编写自己的底层事务处理代码。  C# X! ]) S  x/ X6 m3 Z$ q- t  M
Query和Criteria接口
# t" [- q! r( M7 L! V9 L. s  Query和Criteria接口负责执行各种数据库查询。它可以使用HQL语言或SQL语句两种表达方式。
( f5 R& K% _# \8 d1 e编辑本段Hibernate版本更新情况
( X9 J$ Z! O: E( N* @* a" w  Hibernate版本更新速度很快,目前为止有两个阶段性的版本:Hibernate2和Hibernate3,这一点程序员从其Jar文件名便可以看出来。目前最新发布的版本是Hibernate3.6.1.   Hibernate2系列的最高版本是Hibernate2.1.8,Hibernate3系列的最高版本是Hibernate 3.2.5 GA版,GA也就是General Availability,即推荐广泛使用的版本,但目前使用较多且较稳定的版本是Hibernate 3.1.3或Hibernat 3.1.2.   另外,自Hibernate3发布以来,其产品线愈加成熟,相继出现了Hibernate注释、Hibernate实体管理器、Hibernate插件工具等一系列产品套件。在方便程序员使用Hibernate进行应用程序的开发的同时,也逐渐增强了Hibernate产品线的实力。   但目前市面上用于学习Hibernate开发的图书并不多见,大多是介绍老版的Hibernate2,最近希赛和博文联手推出的《贯通Hibernate开发》,对最新的Hibernate3作了详尽的解答,推荐读者阅读。
* P' y% q5 x1 p2 Z  @; y2 k编辑本段Hibernate主键介绍
8 S( X4 Z0 O: O! Q& q. f  z7 VAssigned
0 x1 @) l/ g: f3 X" S& _  Assigned方式由用户生成主键值,并且要在save()之前指定否则会抛  Hibernate相关书籍" v( }. \  ^" x0 S7 f6 w  {
出异常   特点:主键的生成值完全由用户决定,与底层数据库无关。用户需要维护主键值,在调用session.save()之前要指定主键值。
" f. W2 u8 f4 \' q# ?0 Z/ MHilo7 S5 ]' V: }! W% o; X$ U: K( ~! u- \
  Hilo使用高低位算法生成主键,高低位算法使用一个高位值和一个低位值,然后把算法得到的两个值拼接起来作为数据库中的唯一主键。Hilo方式需要额外的数据库表和字段提供高位值来源。默认请况下使用的表是   hibernate_unique_key,默认字段叫作next_hi。next_hi必须有一条记录否则会出现错误。   特点:需要额外的数据库表的支持,能保证同一个数据库中主键的唯一性,但不能保证多个数据库之间主键的唯一性。Hilo主键生成方式由Hibernate 维护,所以Hilo方式与底层数据库无关,但不应该手动修改hi/lo算法使用的表的值,否则会引起主键重复的异常。) X7 L& U& y7 ~+ Q5 Y* e' C
Increment# D( c1 M" O  F. C
  Increment方式对主键值采取自动增长的方式生成新的主键值,但要求底层数据库的支持Sequence。如Oracle,DB2等。需要在映射文件xxx.hbm.xml中加入Increment标志符的设置。   特点:由Hibernate本身维护,适用于所有的数据库,不适合多进程并发更新数
回复

使用道具 举报

326

主题

72

听众

999

金钱

实习版主

该用户从未签到

优秀版主

7#
发表于 2014-03-11 21:44:07 |只看该作者
Query和Criteria接口2 {7 F' H1 ~8 i' q6 [9 X
Hibernate版本更新情况$ R1 `0 l. y7 @
Hibernate主键介绍Assigned
- O' M  V4 S! M- K! JHilo5 K3 i4 U, L: N& X5 `1 n- n2 T3 |
Increment
' p, @; ]$ k, `! v& [& PIdentity
9 I4 \  W# `2 H3 Y, hSequence3 c* v3 g  k* y& m" g4 e- M
Native. @: b! z9 k9 `. D  E. L  l
UUID
4 Z* b" g: j& ^0 LForeign GUID1 D( e7 K5 s5 ^/ B9 @+ f6 ?# t( |
Hibernate源码中几个包的作用简要介绍
6 {. e, V$ c  W缓存管理一级缓存和二级缓存的比较) W0 B  @* C8 C( L& X7 H8 ~) V
一级缓存的管理0 w! S0 w' D4 C6 d' C
二级缓存的管理
, ^+ r8 L4 l5 H$ c6 tHibernate与延迟加载
0 r9 J6 w  r* w* q* F! a4 [* e$ G+ l在Web层进行延迟加载核心接口简介 Session接口 ! u: c0 Z1 W( t* ]
SessionFactory接口 ; g* T2 Q, p+ @+ B0 ^4 t1 g6 m
Configuration接口
/ ?# o: n" \  Y+ R5 xTransaction接口 # g, I' J2 ?2 j" C& _
Query和Criteria接口
$ R. k. c: Q9 X" H* aHibernate版本更新情况
: e) V4 Q: S& f% aHibernate主键介绍 Assigned
( r  t+ W- Q+ U" w- P* K- IHilo ( x$ U2 o" D+ p4 l
Increment ' j' P; \/ g* c+ H* C; Y8 h. W7 k
Identity
1 }+ l! J$ q; h. y0 k7 E8 nSequence 3 z5 Z8 a- J0 I7 L4 Y7 }
Native
: a( e- f2 {2 tUUID 8 u0 l1 F. ?/ J* Q* U
Foreign GUID
9 b8 B& c: i! Z7 y: ^2 wHibernate源码中几个包的作用简要介绍
# K: i" X8 c* j% c7 E% O) l: Q缓存管理 一级缓存和二级缓存的比较 ; X1 I; c2 B4 I2 q* C
一级缓存的管理
4 O+ H2 K( n0 F, ~# V二级缓存的管理
  `' E3 g8 [# Z3 UHibernate与延迟加载 / e, ?' |7 Q+ I
在Web层进行延迟加载
# p  D# I  J- Y% J% ?展开 编辑本段核心接口简介  [" ]3 c7 W9 L0 k* v5 y9 n
  Hibernate的核心接口一共有5个,分别为:Session、SessionFactory、Transaction、Query和Configuration。这5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。下面对这五个核心接口分别加以介绍。     
7 W  I/ B  }. l- qSession接口
% |4 d( {* n* e! M; P: q  Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。
$ E! z4 a3 H& n. O5 G) u3 ~( z
回复

使用道具 举报

快速回复
您需要登录后才可以回帖 登录 | 立即注册

   

关闭

站长推荐上一条 /1 下一条

发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
快速回复 返回顶部 返回列表