书籍详情

Hibernate实战(第二版)

Hibernate实战(第二版)

作者:(德国)Christian Bauer、(澳大利亚)Gavin King 著;杨春花、彭永康 译

出版社:人民邮电出版社

出版时间:2008-04-01

ISBN:9787115174482

定价:¥99.00

购买这本书可以去
内容简介
  《图灵程序设计丛书·Hibernate实战(第2版)》是毋庸置疑的Hibernate和ORM(对象/关系映射)权威著作,由包括Hibernate之父在内的两位核心开发人员亲自执笔,详细讲述了Hibernate 3.2、Java Persistence和EJB 3.0标准。《图灵程序设计丛书·Hibernate实战(第2版)》通过一个应用将数百个例子融合起来,不仅深入剖析了Hibernate 3.2和Java Persistence丰富的编程模型。还深刻阐述了数据库设计、ORM和优化等方面的基本原则、策略和最佳实践。书中处处闪烁着作者超凡的真知灼见,将大大升华读者对ORM乃至企业级应用开发的理解。
作者简介
  Christian Bauer,Hibernate核心开发人员,并负责维护Hibernate的文档与网站。目前他是Red Hat公司JBoss部门负责Hibernate、EJB 3.0和Seam的产品经理。
目录
第一部分  从Hibernate和EJB 3.0开始
第1章  理解对象/关系持久化 2
1.1  什么是持久化 3
1.1.1  关系数据库 3
1.1.2  理解SQL 4
1.1.3  在Java中使用SQL 5
1.1.4  面向对象应用程序中的持久化 5
1.2  范式不匹配 6
1.2.1  粒度问题 8
1.2.2  子类型问题 9
1.2.3  同一性问题 10
1.2.4  与关联相关的问题 11
1.2.5  数据导航的问题 12
1.2.6  不匹配的代价 13
1.3  持久层和其他层 14
1.3.1  分层架构 14
1.3.2  用SQL/JDBC手工编写持久层 15
1.3.3  使用序列化 16
1.3.4  面向对象的数据库系统 16
1.3.5  其他选项 17
1.4  ORM 17
1.4.1  什么是ORM 17
1.4.2  一般的ORM问题 19
1.4.3  为什么选择ORM 19
1.4.4  Hibernate、EJB 3和JPA简介 21
1.5  小结 24
第2章  启动项目 25
2.1  启动Hibernate项目 25
2.1.1  选择开发过程 26
2.1.2  建立项目 28
2.1.3  Hibernate配置和启动 34
2.1.4  运行和测试应用程序 42
2.2  启动Java Persistence项目 48
2.2.1  使用Hibernate Annotations 48
2.2.2  使用Hibernate EntityManager 51
2.2.3  引入EJB组件 57
2.2.4  切换到Hibernate接口 62
2.3  反向工程遗留数据库 64
2.3.1  创建数据库配置 64
2.3.2  定制反向工程 65
2.3.3  生成Java源代码 67
2.4  与Java EE服务整合 69
2.4.1  与JTA整合 70
2.4.2  JNDI绑定的SessionFactory 73
2.4.3  JMX服务部署 75
2.5  小结 75
第3章  领域模型和元数据 77
3.1  CaveatEmptor应用程序 77
3.1.1  分析业务领域 78
3.1.2  CaveatEmptor领域模型 78
3.2  实现领域模型 80
3.2.1  处理关注点渗漏 81
3.2.2  透明和自动持久化 81
3.2.3  编写POJO和持久化实体类 82
3.2.4  实现POJO关联 84
3.2.5  把逻辑添加到访问方法 88
3.3  ORM元数据 89
3.3.1  XML中的元数据 89
3.3.2  基于注解的元数据 91
3.3.3  使用XDoclet 95
3.3.4  处理全局的元数据 97
3.3.5  运行时操作元数据 101
3.4  其他实体表示法 102
3.4.1  创建动态的应用程序 103
3.4.2  表示XML中的数据 108
3.5  小结 112
第二部分 映射概念和策略
第4章  映射持久化类 114
4.1  理解实体和值类型 114
4.1.1  细粒度的领域模型 114
4.1.2  定义概念 115
4.1.3  识别实体和值类型 115
4.2  映射带有同一性的实体 117
4.2.1  理解Java同一性和等同性 117
4.2.2  处理数据库同一性 117
4.2.3  数据库主键 120
4.3  类映射选项 123
4.3.1  动态的SQL生成 123
4.3.2  使实体不可变 124
4.3.3  给查询命名实体 125
4.3.4  声明包名称 125
4.3.5  用引号把SQL标识符括起来 126
4.3.6  实现命名约定 126
4.4  细粒度的模型和映射 127
4.4.1  映射基础属性 128
4.4.2  映射组件 133
4.5  小结 137
第5章  继承和定制类型 139
5.1  映射类继承 139
5.1.1  每个带有隐式多态的具体类一张表 140
5.1.2  每个带有联合的具体类一张表 142
5.1.3  每个类层次结构一张表 145
5.1.4  每个子类一张表 148
5.1.5  混合继承策略 151
5.1.6  选择策略 154
5.2  Hibernate类型系统 155
5.2.1  概述实体和值类型 155
5.2.2  内建的映射类型 156
5.2.3  使用映射类型 160
5.3  创建定制的映射类型 161
5.3.1  考虑定制的映射类型 161
5.3.2  扩展点 162
5.3.3  定制映射类型的案例 163
5.3.4  创建UserType 164
5.3.5  创建CompositeUserType 166
5.3.6  参数化定制类型 169
5.3.7  映射枚举 171
5.4  小结 175
第6章  映射集合和实体关联 177
6.1  值类型的set、bag、list和map 177
6.1.1  选择集合接口 178
6.1.2  映射set 179
6.1.3  映射标识符bag 180
6.1.4  映射list 181
6.1.5  映射map 182
6.1.6  排序集合和有序集合 183
6.2  组件的集合 185
6.2.1  编写组件类 185
6.2.2  映射集合 186
6.2.3  启用双向导航 186
6.2.4  避免非空列 187
6.3  用注解映射集合 189
6.3.1  基本的集合映射 189
6.3.2  排序集合和有序集合 190
6.3.3  映射嵌入式对象的集合 191
6.4  映射父/子关系 192
6.4.1  多样性 193
6.4.2  最简单的可能关联 193
6.4.3  使关联双向 195
6.4.4  级联对象状态 197
6.5  小结 203
第7章  高级实体关联映射 204
7.1  单值的实体关联 204
7.1.1  共享的主键关联 205
7.1.2  一对一的外键关联 208
7.1.3  用联结表映射 210
7.2  多值的实体关联 213
7.2.1  一对多关联 214
7.2.2  多对多关联 219
7.2.3  把列添加到联结表 223
7.2.4  映射map 229
7.3  多态关联 231
7.3.1  多态的多对一关联 232
7.3.2  多态集合 233
7.3.3  对联合的多态关联 234
7.3.4  每个具体类一张多态表 236
7.4  小结 238
第8章  遗留数据库和定制SQL 239
8.1  整合遗留数据库 239
8.1.1  处理主键 240
8.1.2  带有公式的任意联结条件 250
8.1.3  联结任意的表 254
8.1.4  使用触发器 257
8.2  定制SQL 260
8.2.1  编写定制CRUD语句 261
8.2.2  整合存储过程和函数 265
8.3  改进Schema DDL 271
8.3.1  定制SQL名称和数据类型 271
8.3.2  确保数据一致性 273
8.3.3  添加领域约束和列约束 274
8.3.4  表级约束 276
8.3.5  数据库约束 278
8.3.6  创建索引 279
8.3.7  添加辅助的DDL 280
8.4  小结 282
第三部分 会话对象处理
第9章  使用对象 284
9.1  持久化生命周期 284
9.1.1  对象状态 285
9.1.2  持久化上下文 287
9.2  对象同一性和等同性 289
9.2.1  引入对话 289
9.2.2  对象同一性的范围 290
9.2.3  脱管对象的同一性 292
9.2.4  扩展持久化上下文 296
9.3  Hibernate接口 296
9.3.1  保存和加载对象 297
9.3.2  使用脱管对象 302
9.3.3  管理持久化上下文 306
9.4  JPA 308
9.4.1  保存和加载对象 309
9.4.2  使用脱管的实体实例 312
9.5  在EJB组件中使用Java Persistence 315
9.5.1  注入EntityManager 315
9.5.2  查找EntityManager 317
9.5.3  访问EntityManagerFactory 318
9.6  小结 319
第10章  事务和并发 320
10.1  事务本质 320
10.1.1  数据库和系统事务 321
10.1.2  Hibernate应用程序中的事务 323
10.1.3  使用Java Persistence的事务 331
10.2  控制并发访问 334
10.2.1  理解数据库级并发 334
10.2.2  乐观并发控制 338
10.2.3  获得额外的隔离性保证 343
10.3  非事务数据访问 346
10.3.1  揭开自动提交的神秘面纱 346
10.3.2  使用Hibernate非事务地工作 347
10.3.3  使用JTA的可选事务 349
10.4  小结 349
第11章  实现对话 351
11.1  传播Hibernate Session 351
11.1.1  Session传播的用例 352
11.1.2  通过线程局部传播 353
11.1.3  利用JTA传播 355
11.1.4  利用EJB传播 356
11.2  利用Hibernate的对话 357
11.2.1  提供对话保证 357
11.2.2  利用脱管对象的对话 358
11.2.3  给对话扩展Session 360
11.3  使用JPA的对话 366
11.3.1  Java SE中的持久化上下文传播 367
11.3.2  在对话中合并脱管对象 368
11.3.3  在Java SE中扩展持久化上下文 369
11.4  使用EJB 3.0的对话 373
11.4.1  使用EJB的上下文传播 373
11.4.2  利用EJB扩展持久化上下文 376
11.5  小结 380
第12章  有效修改对象 381
12.1  传播性持久化 381
12.1.1  按可到达性持久化 382
12.1.2  把级联应用到关联 383
12.1.3  使用传播性状态 386
12.1.4  利用JPA的传播性关联 391
12.2  大批量和批量操作 392
12.2.1  使用HQL和JPA QL的大批量语句 392
12.2.2  利用批量处理 395
12.2.3  使用无状态的会话 397
12.3  数据过滤和拦截 398
12.3.1  动态数据过滤 399
12.3.2  拦截Hibernate事件 402
12.3.3  内核事件系统 408
12.3.4  实体监听器和回调 410
12.4  小结 411
第13章  优化抓取和高速缓存 412
13.1  定义全局抓取计划 412
13.1.1  对象获取选项 412
13.1.2  延迟的默认抓取计划 415
13.1.3  理解代理 415
13.1.4  禁用代理生成 417
13.1.5  关联和集合的即时加载 418
13.1.6  通过拦截延迟加载 420
13.2  选择抓取策略 422
13.2.1  批量预抓取数据 422
13.2.2  通过子查询预抓取集合 424
13.2.3  通过联结即时抓取 425
13.2.4  给二级表优化抓取 428
13.2.5  优化指导方针 430
13.3  高速缓存基本原理 436
13.3.1  高速缓存策略和范围 436
13.3.2  Hibernate高速缓存架构 439
13.4  高速缓存实践 442
13.4.1  选择并发控制策略 442
13.4.2  理解高速缓存区域 444
13.4.3  设置本地的高速缓存提供程序 445
13.4.4  设置重复的高速缓存 446
13.4.5  控制二级高速缓存 449
13.5  小结 451
第14章  利用HQL和JPA QL查询 452
14.1  创建和运行查询 452
14.1.1  准备查询 453
14.1.2  执行查询 460
14.1.3  使用具名查询 463
14.2  基本的HQL和JPA QL查询 465
14.2.1  选择 466
14.2.2  限制 467
14.2.3  投影 472
14.3  联结、报表查询和子查询 473
14.3.1  联结关系和关联 473
14.3.2  报表查询 482
14.3.3  利用子查询 485
14.4  小结 487
第15章  高级查询选项 488
15.1  利用条件和示例查询 488
15.1.1  基本的条件查询 489
15.1.2  联结和动态抓取 493
15.1.3  投影和报表查询 497
15.1.4  按示例查询 500
15.2  利用原生的SQL查询 503
15.2.1  自动的结果集处理 503
15.2.2  获取标量值 504
15.2.3  Java Persistence中的原生SQL 505
15.3  过滤集合 507
15.4  高速缓存查询结果 508
15.4.1  启用查询结果高速缓存 509
15.4.2  理解查询高速缓存 509
15.4.3  什么时候使用查询高速缓存 510
15.4.4  自然标识符高速缓存查找 511
15.5  小结 512
第16章  创建和测试分层的应用程序 513
16.1  Web应用程序中的Hibernate 513
16.1.1  用例简介 514
16.1.2  编写控制器 514
16.1.3  OSIV模式 516
16.1.4  设计巧妙的领域模型 518
16.2  创建持久层 521
16.2.1  泛型的数据访问对象模式 521
16.2.2  实现泛型CRUD接口 523
16.2.3  实现实体DAO 525
16.2.4  利用数据访问对象 526
16.3  命令模式简介 529
16.3.1  基础接口 530
16.3.2  执行命令对象 531
16.3.3  命令模式的变形 533
16.4  利用EJB 3.0设计应用程序 534
16.4.1  利用有状态的bean实现会话 534
16.4.2  利用EJB编写DAO 536
16.4.3  利用依赖注入 537
16.5  测试 538
16.5.1  理解不同种类的测试 539
16.5.2  TestNG简介 539
16.5.3  测试持久层 542
16.5.4  考虑性能基准 549
16.6  小结 550
第17章  JBoss Seam简介 551
17.1  Java EE 5.0编程模型 551
17.1.1  JSF详解 552
17.1.2  EJB 3.0详解 553
17.1.3  用JSF和EJB 3.0编写Web应用程序 554
17.1.4  分析应用程序 562
17.2  用Seam改善应用程序 564
17.2.1  配置Seam 565
17.2.2  将页面绑定到有状态的Seam组件 566
17.2.3  分析Seam应用程序 570
17.3  理解上下文组件 575
17.3.1  编写登录页面 575
17.3.2  创建组件 577
17.3.3  给上下文变量起别名 579
17.3.4  完成登录/注销特性 580
17.4  验证用户输入 583
17.4.1  Hibernate Validator简介 584
17.4.2  创建注册页面 584
17.4.3  用Seam实现国际化 591
17.5  利用Seam简化持久化 594
17.5.1  实现对话 595
17.5.2  让Seam管理持久化上下文 601
17.6  小结 604
附录A  SQL基础知识 606
附录B  映射快速参考 609
猜您喜欢

读书导航