第1章Java应用分层架构及软件模型1
1.1应用程序的分层体系结构1
1.1.1区分物理层和逻辑层2
1.1.2软件层的特征3
1.1.3软件分层的优点4
1.1.4软件分层的缺点4
1.1.5Java应用的持久化层5
1.2软件的模型6
1.2.1概念模型7
1.2.2关系数据模型8
1.2.3域模型10
1.2.4域对象10
1.2.5域对象之间的关系11
1.2.6域对象的持久化概念17
1.3小结19
1.4思考题19
第2章Java对象持久化技术概述21
2.1直接JDBCAPI来持久化实体域对象21
2.2ORM简介27
2.2.1对象-关系映射的概念29
2.2.2ORM中间件的基本使用方31
2.2.3常用的ORM中间件33
2.3实体域对象的其他持久化模34
2.3.1主动域对象模35
2.3.2JDO模37
2.3.3CMP模37
2.4HibernateAPI简介38
2.4.1Hibernate的心接口39
2.4.2处理接口41
2.4.3Hibernate映射类型接口41
2.4.4可供扩展的接口42
2.5小结43
2.6思考题45
第3章一个Hibernate应用47
3.1创建Hibernate的配置文件47
3.2创建持久化类48
3.3创建数据库Schema51
3.4创建对象-关系映射文件52
3.4.1映射文件的文档类型定义(DTD)52
3.4.2把Customer持久化类映射到CUSTOMERS表54
3.5HibernateAPI纵数据库58
3.5.1Hibernate的初始化61
3.5.2访问Hibernate的Session接口63
3.6运行helloapp应用67
3.6.1创建运行本书范例的系统环境67
3.6.2创建helloapp应用的目录结构72
3.6.3把helloapp应用作为应用程序运行73
3.6.4把helloapp应用作为JavaWeb应用运行77
3.7小结78
3.8思考题80
第4章hbm2java和hbm2ddl工83
4.1创建对象-关系映射文件83
4.1.1定制持久化类85
4.1.2定制数据库表88
4.2建立项目的目录结构90
4.3运行hbm2java工93
4.4运行hbm2ddl工94
4.5使用XML格的配置文件96
4.6小结97
4.7思考题98
第5章对象-关系映射基础101
5.1持久化类的属性及访问方101
5.1.1基本类型属性和包装类型属性102
5.1.2Hibernate访问持久化类属性的策略104
5.1.3在持久化类的访问方中加入程序逻辑104
5.1.4设置派生属性107
5.1.5控制insert和update语句108
5.2处理SQL引用标识符109
5.3创建命名策略110
5.4设置数据库Schema112
5.5设置类的包名113
5.6运行本章的范例程序114
5.7小结120
5.8思考题121
第6章映射对象标识符123
6.1关系数据库按主键区分不同的记录123
6.1.1把主键定义为自动增长标识符类型123
6.1.2从序列(Sequence)中获取自动增长的标识符124
6.2Java语言按内存地址区分不同的对象125
6.3Hibernate用对象标识符(OID)来区分对象126
6.4Hibernate的内置标识符生成器的用128
6.4.1increment标识符生成器131
6.4.2identity标识符生成器133
6.4.3sequence标识符生成器134
6.4.4hilo标识符生成器135
6.4.5native标识符生成器137
6.5映射自然主键138
6.5.1映射单个自然主键138
6.5.2映射复合自然主键140
6.6小结143
6.7思考题144
第7章映射一对多关联关系147
7.1建立多对一的单向关联关系148
7.1.1元素的not-null属性153
7.1.2级联保存和更新155
7.2映射一对多双向关联关系156
7.2.1元素的inverse属性161
7.2.2级联163
7.2.3父子关系164
7.3映射一对多双向自身关联关系165
7.4改持久化类171
7.5小结175
7.6思考题176
第8章Hibernate纵对象(上)179
8.1Java对象在JVM中的生命周期179
8.2理解Session的缓存181
8.2.1Session的缓存的作用182
8.2.2脏检查及清理缓存的机制184
8.3Java对象在Hibernate持久化层的状态187
8.3.1临时对象的特征188
8.3.2持久化对象的特征189
8.3.3被对象的特征190
8.3.4游离对象的特征191
8.4Session接口的详细用191
8.4.1Session的save()和persist()方191
8.4.2Session的load()和get()方194
8.4.3Session的update()方195
8.4.4Session的saveOrUpdate()方197
8.4.5Session的merge()方198
8.4.6Session的delete()方200
8.4.7Session的replicate()方201
8.5级联纵对象图202
8.5.1级联保存临时对象206
8.5.2更新持久化对象207
8.5.3持久化临时对象207
8.5.4更新游离对象209
8.5.5遍历对象图210
8.6小结211
8.7思考题211
第9章Hibernate纵对象(下)215
9.1与触发器协同工作215
9.2利用拦截器(Interceptor)生成审计日志217
9.3Hibernate的处理机制224
9.4批量处理数据226
9.4.1Session来行批量作227
9.4.2StatelessSession来行批量作229
9.4.3HQL来行批量作230
9.4.4直接JDBCAPI来行批量作232
9.5使用元数据233
9.6Hibernate调用存储过程234
9.7小结234
9.8思考题235
第10章映射组成关系237
10.1建立精粒度对象模型238
10.2建立粗粒度关系数据模型239
10.3映射组成关系240
10.3.1区分值(Value)类型和实体(Entity)类型242
10.3.2在应用程序中访问有组成关系的持久化类244
10.4映射复合组成关系247
10.5小结248
10.6思考题249
第11章Hibernate的映射类型251
11.1Hibernate的内置映射类型251
11.1.1Java基本类型的Hibernate映射类型251
11.1.2Java时间和日期类型的Hibernate映射类型252
11.1.3Java对象类型的Hibernate映射类型253
11.1.4JDK自带的个别Java类的Hibernate映射类型253
11.1.5使用Hibernate内置映射类型254
11.2客户化映射类型256
11.2.1用客户化映射类型取代Hibernate组件260
11.2.2用UserType映射枚举类型263
11.2.3实现CompositeUserType接口266
11.2.4运行本节范例程序271
11.3纵Blob和Clob类型数据279
11.4小结284
11.5思考题284
第12章映射继承关系287
12.1继承关系树的每个体类对应一个表288
12.1.1创建映射文件289
12.1.2纵持久化对象290
12.2继承关系树的根类对应一个表293
12.2.1创建映射文件294
12.2.2纵持久化对象296
12.3继承关系树的每个类对应一个表297
12.3.1创建映射文件298
12.3.2纵持久化对象300
12.4选择继承关系的映射方302
12.5映射多对一多态关联305
12.6小结308
12.7思考题309
第13章Java集合类311
13.1Set(集)312
13.1.1Set的一般用312
13.1.2HashSet类313
13.1.3TreeSet类315
13.1.4向Set中加入持久化类的对象319
13.2List(列表)320
13.3Map(映射)321
13.4小结325
13.5思考题326
第14章映射值类型集合327
14.1映射Set(集)327
14.2映射Bag(包)331
14.3映射List(列表)334
14.4映射Map337
14.5对集合排序339
14.5.1在数据库中对集合排序340
14.5.2在内存中对集合排序341
14.6映射组件类型集合345
14.7小结350
14.8思考题351
第15章映射实体关联关系353
15.1映射一对一关联353
15.1.1按照外键映射354
15.1.2按照主键映射358
15.2映射单向多对多关联361
15.3映射双向多对多关联关系365
15.3.1关联两端使用元素366
15.3.2在inverse端使用元素367
15.3.3使用组件类集合371
15.3.4把多对多关联为两个一对多关联376
15.4小结378
15.5思考题379
第16章Hibernate的检索策略381
16.1Hibernate的检索策略简介383
16.2类级别的检索策略386
16.2.1立即检索387
16.2.2延迟检索387
16.3一对多和多对多关联的检索策略390
16.3.1立即检索(lazy属性为“false”)392
16.3.2延迟检索(lazy属性为默认值“true”)392
16.3.3增强延迟检索(lazy属性为“extra”)393
16.3.4批量延迟检索和批量立即检索(使用batch-size属性)393
16.3.5用带子查询的select语句整批量初始化orders集合(fetch属性为“subselect”)396
16.3.6迫切左外连接检索(fetch属性为“join”)397
16.4多对一和一对一关联的检索策略398
16.4.1迫切左外连接检索(fetch属性为“join”)398
16.4.2延迟检索(lazy属性为默认值“proxy”)400
16.4.3无延迟检索(lazy属性为“no-proxy”)401
16.4.4立即检索(lazy属性为“false”)401
16.4.5批量延迟检索和批量立即检索(使用batch-size属性)402
16.5控制迫切左外连接检索的深度405
16.6在应用程序中显指定迫切左外连接检索策略408
16.7属性级别的检索策略408
16.8小结409
16.9思考题411
第17章Hibernate的检索方(上)413
17.1Hibernate的检索方简介413
17.1.1HQL检索方416
17.1.2QBC检索方417
17.1.3本地SQL检索方419
17.1.4关于本章范例程序420
17.1.5使用别名421
17.1.6多态查询421
17.1.7对查询结果排序422
17.1.8分页查询423
17.1.9检索单个对象(uniqueResult()方)424
17.1.10按主键逐个处理查询结果(iterate()方)425
17.1.11可滚动的结果集426
17.1.12在HQL查询语句中绑定参数428
17.1.13设置查询附属事项433
17.1.14在映射文件中定义命名查询语句436
17.1.15在HQL查询语句中调用函数438
17.2设定查询条件439
17.2.1比较运440
17.2.2范围运441
17.2.3字符串模匹配442
17.2.4逻辑运443
17.2.5集合运444
17.3小结445
17.4思考题446
第18章Hibernate的检索方(下)449
18.1连接查询449
18.1.1默认情况下关联级别的运行时检索策略450
18.1.2迫切左外连接451
18.1.3左外连接453
18.1.4内连接457
18.1.5迫切内连接461
18.1.6隐内连接463
18.1.7右外连接464
18.1.8使用SQL风格的交连接和隐内连接466
18.1.9关联级别运行时的检索策略467
18.2投影查询468
18.3报表查询471
18.3.1使用聚集函数471
18.3.2分组查询472
18.3.3优化报表查询的性能475
18.4高级查询技巧475
18.4.1动态查询476
18.4.2集合过滤478
18.4.3子查询480
18.4.4本地SQL查询482
18.4.5查询结果转换器484
18.5查询性能优化486
18.5.1iterate()方486
18.5.2查询缓存487
18.6小结488
18.7思考题489
第19章Hibernate高级配置491
19.1配置数据库连接池491
19.1.1使用默认的数据库连接池494
19.1.2使用配置文件指定的数据库连接池495
19.1.3从容器中获得数据源495
19.1.4由Java应用本身提供数据库连接497
19.2配置事务类型497
19.3把SessionFactory与JNDI绑定500
19.4配置日志502
19.5使用XML格的配置文件505
19.6小结507
19.7思考题508
第20章声明数据库事务511
20.1数据库事务的概念511
20.2声明事务边界的方513
20.3在mysql.exe程序中声明事务515
20.4Java应用JDBCAPI声明JDBC事务517
20.5Java应用HibernateAPI声明JDBC事务518
20.5.1处理异常520
20.5.2Session与事务的关系522
20.5.3设定事务超时525
20.6Java应用HibernateAPI声明JTA事务525
20.7Java应用JTAAPI声明JTA事务526
20.8小结529
20.9思考题530
第21章处理并发问题533
21.1多个事务并发运行时的并发问题533
21.1.1一类丢失更新534
21.1.2脏读535
21.1.3虚读535
21.1.4不可重复读536
21.1.5二类丢失更新536
21.2数据库系统的锁的基本原理537
21.2.1锁的多粒度性及自动锁升级538
21.2.2锁的类型和兼容性538
21.2.3死锁及其防止540
21.3数据库的事务隔离级别541
21.3.1在mysql.exe程序中设置隔离级别543
21.3.2在应用程序中设置隔离级别543
21.4在应用程序中采用悲观锁544
21.4.1利用数据库系统的独占锁来实现悲观锁544
21.4.2由应用程序实现悲观锁550
21.5利用Hibernate的版本控制来实现乐观锁550
21.5.1使用元素551
21.5.2使用元素556
21.5.3对游离对象行版本检查558
21.5.4强制更新版本559
21.6实现乐观锁的其他方559
21.7小结560
21.8思考题561
第22章管理Hibernate的缓存563
22.1缓存的基本原理563
22.1.1持久化层的缓存的范围564
22.1.2持久化层的缓存的并发访问策略566
22.2Hibernate的二级缓存结构568
22.3管理Hibernate的一级缓存569
22.4管理Hibernate的二级缓存570
22.4.1配置程范围内的二级缓存571
22.4.2配置集群范围内的二级缓存575
22.4.3在应用程序中管理二级缓存578
22.4.4Session与二级缓存的交互模578
22.5运行本章的范例程序579
22.6小结583
22.7思考题584
第23章管理Session和实现对话587
23.1管理Session对象的生命周期587
23.1.1Session对象的生命周期与本地线程绑定590
23.1.2Session对象的生命周期与JTA事务绑定592
23.2实现对话593
23.2.1使用游离对象595
23.2.2使用手工清理缓存模下的Session597
23.3小结603
23.4思考题605
第24章Hibernate与Struts框架607
24.1实现业务数据609
24.2实现业务逻辑612
24.3netstore应用的订单业务622
24.4小结626
第25章Hibernate与EJB组件629
25.1创建EJB组件629
25.1.1编写Remote接口629
25.1.2编写Home接口631
25.1.3编写EnterpriseJavaBean类631
25.2在业务类中访问EJB组件633
25.3发布J2EE应用638
25.3.1在JBoss上部署EJB组件638
25.3.2在JBoss上部署Web应用639
25.3.3在JBoss上部署J2EE应用640
25.4小结642
附录A标准SQL语言的用643
A.1数据完整性644
A.1.1实体完整性644
A.1.2域完整性644
A.1.3参照完整性644
A.2DDL数据定义语言644
A.3DML数据纵语言646
A.4DQL数据查询语言647
A.4.1简单查询648
A.4.2连接查询648
A.4.3子查询651
A.4.4联合查询652
A.4.5报表查询652
附录BJava语言的射机制655
B.1JavaReflectionAPI简介655
B.2运用射机制来持久化Java对象658
附录C用XDoclet工生成映射文件665
C.1创建带有@hibernate标记的Java源文件665
C.2建立项目的目录结构669
C.3运行XDoclet工672
附录D发布和运行netstore应用675
D.1运行netstore所需的软件675
D.2netstore应用的目录结构676
D.3SAMPLEDB数据库677
D.4和配置JBoss器677
D.5发布netstore应用679
D.5.1在工作模1下发布netstore应用679
D.5.2在工作模2下发布netstore应用679
D.6运行netstore应用680
附录EHibernate3升级指南685
E.1HibernateAPI变化685
E.1.1包名685
E.1.2org.hibernate.classic包685
E.1.3Hibernate所依赖的三方软件包686
E.1.4异常模型686
E.1.5Session接口686
E.1.6createSQLQuery()687
E.1.7Lifecycle和Validatable接口687
E.1.8Interceptor接口687
E.1.9UserType和CompositeUserType接口687
E.1.10FetchMode类688
E.1.11PersistentEnum类688
E.1.12对Blob和Clob的支持688
E.1.13Hibernate中供扩展的API的变化688
E.2元数据的变化688
E.2.1检索策略688
E.2.2对象标识符的映射688
E.2.3集合映射689
E.2.4DTD689
E.3查询语句的变化689
E.4把Hibernate2应用升级到Hibernate3应用690
附录F思考题答案691
参考文献693