【转】http://blog.csdn.net/EJB_JPA/archive/2008/04/18/2304472.aspx
第1章 JPA概述
1.1 什么是数据持久化
1.2 Java持久化技术
1.2.1 序列化(Serialization)
1.2.2 JDBC
1.2.3 关系对象映射(ORM)
1.2.4 对象数据库(ODB)
1.2.5 Java数据对象(JDO)
1.2.6 EJB 2.X
1.3 JPA(Java Persistence API)概述
1.3.1 什么是JPA
1.3.2 JPA的历史
1.3.3 下载JPA规范
1.3.4 JPA的优势
1.3.3 EJB3与JPA的关系
1.3.4 常见的实现JPA的框架
1.4 对象关系映射(ORM)
1.4.1 什么是对象关系映射
1.4.2 对象关系映射模式
1.5 本章小结
第2章 搭建JPA开发和运行环境
2.1 JBoss概述
2.1.1 JBoss Application Server
2.1.2 JBoss IDE for Eclipse
2.2 JBoss应用服务器的搭建
2.2.1 下载和安装JBoss服务器
2.2.2 启动JBoss服务器
2.2.3 停止JBoss服务器
2.2.4 JBoss的文件目录结构
2.3 JBoss IDE开发环境的搭建
2.3.1 下载JBoss IDE for Eclipse
2.3.2 Eclipse中配置JBoss
2.3.3 Eclipse中启动和停止JBoss
2.4 MySQL数据库的下载和安装
2.4.1 MySQL数据库概述
2.4.2 下载MySQL
2.4.3 安装MySQL
2.4.4 运行MySQL
2.4.5 下载MySQL客户端
2.5 本章小结
第3章 JPA之初体验
3.1 第一个Entity实体类
3.1.1 第一个POJO类
3.1.2 数据库中对应的表
3.1.3 使用注释(Annotations)配置ORM映射
3.1.4 配置persistence.xml
3.2 第一个SessionBean
3.2.1 定义Remote接口
3.2.2 Session Bean类
3.3 使用EntityManager操作实体
3.3.1 依赖注入EntityManager
3.3.2 添加Entity
3.3.3 根据主键查找Entity
3.3.4 更新Entity
3.3.5 删除Entity
3.3.6 执行查询
3.4 部署EJB
3.4.1 打EJB-JAR包
3.4.2 部署EJB
3.4.3 配置DataSource数据源
3.4.4 启动JBoss服务器
3.4.5 查看JBoss控制台JMX-Console
3.5 调用EJB的Client
3.5.1 TestClient类
3.5.2 运行Client
3.6 本章小结
第4章 JPA开发工具
4.1 Eclipse Dali JPA 概述
4.1.1 什么是Dali JPA
4.1.2 下载Dali JPA
4.1.3 Dali JPA界面预览
4.2 连接数据库
4.3 开始JPA开发
4.3.1 创建JPA项目
4.3.2 创建持久化类
4.5 本章小结
第5章 映射持久化对象(Entity)
5.1 实体映射基础
5.1.1 简单的POJO类
5.1.2 映射实体@Entity
5.1.3 无参的构造方法
5.1.4 实现Serializable接口
5.1.5 可继承性
5.1.6 标注主键@Id
5.1.7 默认实体映射
5.2 映射表和字段
5.2.1 映射表@Table
5.2.2 映射方法和属性@Column
5.2.3 可持久化的基本数据类型
5.2.4 映射优化一:基本数据类型VS封装类
5.2.4 映射优化二:@Basic设置加载方式
5.3 主键映射
5.3.1 主键标识@Id
5.3.2 自增主键
5.3.3 表生成器@ TableGenerator
5.3.4 Sequence生成器@ Sequence
5.3.5 Identity生成器
5.3.6 复合主键@IdClass
5.3.7 嵌入式主键@EmbeddedId
5.3.8 几种主键生成策略的比较
5.4 映射特殊类型
5.4.1 映射Blob和Clob类型@Lob
5.4.2 映射时间(Temporal)类型@Temporal
5.4.3 映射枚举(Enumerated)型
5.5 映射非持久化类型@Transient
5.6 本章小结
第6章 实体关系映射
6.1 实体关系概述
6.1.1 实体关系的方向性
6.1.2 实体关系的数量性
6.2 一对一(@OneToOne)
6.2.1 单向关联(Unidirectional)
6.2.2 一对一@ OneToOne
6.2.3 关联指定列@JoinColumn
6.2.4 双向关联(Bidirectional)
6.2.5 主键关联@PrimaryKeyJoinColumn
6.2.6 默认关联
6.2.7 一对一映射的一般步骤
6.3 一对多(@OneToMany)
6.3.1 一对多模型(单向)
6.3.2 映射策略
6.3.3 映射策略--外键关联
6.3.4 一对多@OneToMany
6.3.5 映射策略—表关联
6.3.6 表关联@ JoinTable
6.3.7 默认关联
6.4 多对一(@ManyToOne)
6.4.1 多对一 模型(单向)
6.4.2 映射策略--外键关联
6.4.3 多对一@ManyToOne
6.4.4 默认关联
6.5 高级一对多和多对一映射
6.5.1 双向关联模型
6.5.2 双向关联
6.5.4 一对多(多对一)映射的一般步骤
6.6 多对多(@ManyToMany)
6.6.1 多对多模型(单向)
6.6.2 映射策略—表关联
6.6.3 @ManyToMany
6.6.4 双向关联模型
6.6.5 默认关联
6.6.6 多对多映射的一般步骤
6.7 集合类的选择
6.5.1 集合类的区别
6.5.2 带排序的集合
6.5.3 带Key值的集合
6.8 关系映射示例:客户关系管理系统
6.8.1 实体关系类图
6.8.2 数据库表结构
6.8.3 客户实体
6.8.4 地址实体
6.8.5 联系人实体
6.8.6 头像实体
6.8.7 电话实体
6.8.8 订单实体
6.8.9 订单明细实体
6.8.10 产品实体
6.9 本章小结
第7章 实体映射的高级应用
7.1 多表映射
7.1.1 两个表映射为一个实体
7.1.2 从表注释@ SecondaryTable
7.1.3 多个表映射为一个实体
7.1.4 多个从表注释@ SecondaryTables
7.2 嵌入映射
7.2.1 嵌入映射表结构
7.2.2 嵌入类
7.2.3 嵌入到实体
7.2.4 映射属性@AttributeOverride
7.3 实体的继承策略
7.3.1 类结构关系图
7.3.2 三种继承策略
7.3.3 继承关系的实体保存在一个表(SINGLE_TABLE)
7.3.4 每个实体子类保存在一个表(JOINED)
7.3.5 每个实体类保存在一个表(TABLE_PER_CLASS)
7.3.5 三种继承策略对比
7.4 深入实体继承
7.4.1 继承自抽象(abstract)实体类
7.4.2 继承自非映射实体类(Mapped Superclasses)
7.4.3 继承自非实体类
7.7.4 继承的设计重构
7.4.5 带继承关系的实体查询(多态)
7.5 本章小结
第8章 实体管理器(EntityManager)
8.1 实体管理器概述
8.1.1 什么是实体管理器
8.1.2 Entity Manager API
8.1.3 EntityManager方法详解
8.2 操作实体 (CRUD)
8.2.1 创建实体(持久化)
8.2.2 持久化带关系的实体
8.2.3 根据主键查找实体
8.2.4 实体属性及实体的加载方式
8.2.5 更新实体
8.2.6 更新实体关系
8.2.7 删除实体
8.2.8 删除关联的实体
8.3 实体的生命周期
8.3.1 实体的几种状态
8.3.2 瞬时状态(Transient)
8.3.3 持久化状态(Persisted)
8.3.4 托管状态(Attatched或者Managed)
8.3.5 游离状态(Detached)
8.3.6 销毁状态(Removed)
8.3.7 分析实体状态实例
8.4 实体的高级操作
8.4.1 实体的联级操作
8.4.2 获得实体的另一种方式
8.4.3 同步数据库(flush与flushType)
8.4.4 refresh()和clear()方法
8.5 实体监听器(Listener)
8.5.1 回调事件(Callback Events)
8.5.2 监听器定义在实体中
8.5.3 监听器定义在实体外
8.5.4 默认的实体监听器
8.5.5 继承中的实体监听器
8.5.6 监听器的调用顺序
8.5.7 几种监听实体方式的比较
8.7 本章小结
第9章 查询(Query)
9.1 Query 概述
9.1.1 一个简单的查询示例
9.1.2 Query API
9.1.3 Query 方法详解
9.1.4 Query的简化写法
9.2 JPQL入门
9.2.1 查询实体
9.2.2 查询实体属性
9.2.3 查询关联实体
9.3 准备查询
9.3.1 查询参数方法一----命名设置参数
9.3.2 查询参数方法二----位置设置参数
9.3.3 不带参数的查询
9.3.4 查询策略的选择
9.3.5 分页查询
9.3.6 设置提示(Hints)
9.3.7 设置提交模式(FlushMode)
9.4 命名查询(Named Query)
9.4.1 命名查询示例
9.4.2 定义查询命名
9.4.3 @NamedQuery注释
9.5 查询结果的处理
9.5.1 执行查询
9.5.2 查询结果的类型
9.5.3 查询结果为实体
9.5.4 查询结果为基本数据类型
9.5.5 查询结果为数组
9.5.6 查询结果为自定义对象
9.6 本地查询(Native Query)
9.6.1 本地查询概述
9.6.2 执行本地查询
9.6.3 查询结果与实体映射
9.6.4 自定义查询映射
9.6.5 @SqlResultSetMapping
9.6.6 @NamedNativeQuery本地命名查询
9.7 查询技巧
9.7.1 日期类型的查询
9.7.2 动态查询
9.8 本章小结
第10章 查询语言(JPQL)
10.1 JPQL基础
10.1.1 JPQL基本语法
10.1.2 SELECT子句
10.1.3 继承实体的查询
10.2 FROM语句
10.2.1 FROM基本语法
10.2.2 基于集合实体的查询(关联查询)
10.2.3 关联查询
10.2.4 内连接(INNER JOIN)
10.2.5 左连接(LEFT JOIN)
10.2.6 抓取连接(FETCH JOIN)
10.2.7 唯一性查询(DISTINCT)
10.3 WHERE语句
10.3.1 WHERE基本语法
10.3.2 直接量(Literals)
10.3.3 查询条件操作符优先级
10.3.4 算术操作符(Arithmetic Operators)
10.3.5 逻辑操作符(Logic Operators)
10.3.6 比较操作符(Comparison Operators)
10.3.7 BETWEEN操作符
10.3.8 IN操作符
10.3.9 LIKE操作符
10.3.10 NULL操作符
10.3.11 EMPTY操作符
10.3.12 MEMBER OF操作符
10.4 函数表达式
10.4.1 字符串函数
10.4.2 数值函数
10.4.3 日期函数
10.5 子查询
10.5.1 基本子查询
10.5.2 EXISTS表达式
10.5.3 ALL和ANY表达式
10.6 分组查询
10.6.1 分组查询基本语法
10.6.2 分组查询函数
10.7 ORDER BY表达式
10.8 批量操作
10.7.1 批量更新
10.7.2 批量删除
10.7.3 执行批量操作
10.9 本章小节
第11章 持久化上下文
11.1 获得EntityManger对象
11.1.1 Java EE环境与J2SE环境
11.1.2 两种类型的EntityManger对象
11.1.3 容器托管的(container-managed)EntityManger对象
11.1.4 应用托管(application-managed)EntityManger对象
11.1.5 ThreadLocal的使用
11.2 实体管理器工厂(EntityManagerFactory)
11.2.1 javax.persistenc.Persistence API
11.2.2 EntityManagerFactory API
11.2.3 实现自己的JPA
11.3 容器托管的EntityManger持久化上下文
11.3.1 事务范围TRANSACTION
11.3.2 扩展范围EXTENDED
11.3 事务管理
11.3.1 事务与EntityManger
11.3.2 JTA管理事务
11.3.3 RESOURCE_LOCAL管理事务
11.3.4 EntityTransaction API
11.5 应用托管的EntityManger的持久化上下文
11.5.1 无状态的会话Bean与JTA事务(事务范围)
11.5.2 无状态的会话Bean与JTA事务(扩展范围)
11.5.3 有状态的会话Bean与JTA事务
11.5.4 RESOURCE_LOCAL事务
11.6 本章小节
第12章 XML映射文件
12.1 XML映射配置VS注释
12.2 映射文件概述
12.2.1 映射文件的保存位置
12.2.2 获取映射文件DTD
12.3 映射基础
12.3.1 映射文件的基本结构
12.3.2 映射文件的基本元素
12.4 配置注释< persistence-unit-metadata >
12.4.1 禁用注释< xml-mapping-metadata-complete >
12.4.2 持久化单元的默认配置< persistence-unit-defaults >
12.5 映射文件的默认配置
12.5.1 <package>默认包名
12.5.2 <schema>默认schema
12.5.3 <catalog>默认catalog
12.5.4 <access>默认访问类型
12.6 配置查询、生成器和查询结果
12.6.1 <sequence-generator> sequence生成器
12.6.2 <table-generator>表生成器
12.6.3 <named-query>命名查询
12.6.4 <named-native-query>本地命名查询
12.6.5 <sql-result-set-mapping>查询结果映射
12.7 <entity>配置实体
12.7.1 <entity>基本配置
12.7.2 <table>配置表
12.7.3 <secondary-table>配置从表
12.7.4 <attributes>配置属性
12.7.5 配置实体关系
12.8 配置继承
12.8.1 配置所有实体保存为一个表(SINGLE_TABLE)
12.8.2 每个实体子类保存在一个表(JOINED)
12.8.3 <mapped-superclass>配置非实体类
12.9 配置嵌入类
12.9.1 <embeddable>配置类
12.9.2 <embedded>和<attribute-override>配置嵌入实体类
12.10 配置实体监听器
12.10.1 监听器定义在实体内
12.10.2 监听器定义在实体外
12.10.3 禁用父类监听器
12.10.4 禁用默认监听器
12.11 本章小结
第13章 打包和部署
13.1 Java EE应用打包概述
13.1.1 Java EE包的类型
13.1.2 EAR包结构
13.1.3 EJB-JAR包结构
13.1.4 WAR包结构
13.2 Java EE类加载机制
13.2.1 Java类加载器
13.2.2 类加载顺序模型
13.2.3 Java EE应用的加载顺序
13.2.4 类加载原理示例
13.3 配置persistence.xml
13.3.1 保存位置
13.3.2 persistence.xml的基本结构
13.3.3 配置持久化单元名称
13.3.4 配置事务类型
13.3.5 配置实现者
13.3.6 配置数据源
13.3.7 配置映射文件
13.3.8 配置管理类
13.3.9 配置自定义配置
13.4 JPA打包最佳实践
13.4.1 J2SE打包最佳实践
13.4.2 J2EE打包最佳实践—与EJB组件
13.4.3 J2EE打包最佳实践—与Web应用
13.5 本章小结
第14章 JPA实现框架
14.1 Hibernate JPA
14.1.1 Hibernate 与JPA
14.1.2 Hibernate下载
14.1.3 配置方式
14.1.4 基本配置
14.1.5 配置日志
14.1.6 配置缓存
14.1.7 配置JDBC和数据库
14.1.8 其他的常用配置
14.2 OpenJPA
14.2.1 OpenJPA与JPA
14.2.2 OpenJPA下载
14.2.3 配置日志
14.2.4 配置缓存
14.2.5 配置JDBC和数据库
14.2.6 增强器的使用(Enhancer)
14.3 Toplink JPA
14.3.1 Toplink 与JPA
14.3.2 Toplink下载
14.3.3 配置日志
14.3.4 配置缓存
14.3.5 配置JDBC和数据库
14.3.6 配置DDL
14.3.7 其他自定义配置
14.3.8 配置查询优化
14.3.9 加载优化
14.4 本章小结
第15章 JPA与Spring集成
15.1 Spring概述
15.1.1 什么是Spring
15.1.2 Spring的特性
15.1.3 Spring与JPA
15.2 开始Spring之旅
15.2.1 IoC容器
15.2.2 普通的Bean
15.2.3 容器管理的Bean
15.2.4 在容器中运行
15.3 Spring中集成JPA
15.3.1 集成前的准备
15.3.2 配置EntityManagerFactory
15.3.3 配置事务Transaction
15.3.4 运行程序
15.4 Spring Web框架
15.4.1 Spring Web概述
15.4.2 配置Spring Web应用
15.4.3 开始Spring Web之旅
15.5 Spring Web集成JPA
15.5.1 集成前的准备
15.5.2 配置数据源
15.5.3 注入业务逻辑
15.5.4 运行程序
15.6 本章小结
第16章 学生成绩管理系统(Servlet+JPA)
16.1 系统概述
16.1.1 需求描述
16.1.2 系统预览
16.2 系统构架
16.2.1 系统结构
16.2.2 CharacterFilter
16.2.3 异常处理
16.3 数据库设计
16.3.1 数据表UML
16.3.2 SQL脚本
16.4 JPA实体设计
16.4.1 JPA实体UML
16.4.2 JPA实体类代码
16.4.3 persistence.xml配置
16.4.4 JPA实体的部署
16.5 班级模块
16.5.1 添加页面addClass.jsp
16.5.2 添加班级
16.5.3 使用标注获取EntityManagerFactory
16.5.4 班级列表
16.5.5 修改班级
16.5.6 删除班级
16.6 课程模块
16.6.1 添加删除修改课程
16.6.2 选择听课学生
16.7 学生模块
16.7.1 分页显示学生列表
16.7.2 添加修改删除学生
16.8 分数模块
16.8.1 添加学生成绩
16.8.2 列出学生成绩
16.9 本章小结
第17章 宠物商店(Swing+JPA)
17.1 系统概述
17.1.1 需求描述
17.1.2 系统预览
17.2 系统构架
17.2.1 系统构架
17.2.2 实体类设计
17.2.3 业务类实现
17.2.4 Session Bean查找
17.2.5 persistence.xml配置
17.2.6 EJB3组件部署
17.3 登录对话框
17.3.1 登录对话框
17.3.2 异常信息显示
17.4 主购物窗口
17.4.1 主购物窗口
17.4.2 主购物窗口代码
17.4.3 宠物列表Model
17.4.4 添加宠物类别命令
17.4.5 删除宠物类别命令
17.4.6 添加宠物命令
17.5 购买窗口
17.5.1 购买对话框
17.5.2 购物车对话框
17.5.3 付款操作
17.6 本章小结
第18章 博客系统(Struts2+Spring2 +JPA)
18.1 系统概述
18.1.1 需求描述
18.1.2 系统预览
18.2 系统构架
18.2.1 系统构架
18.2.2 执行流程
18.3 实体类设计
18.3.1 基础实体BaseBean
18.3.2 用户实体Person
18.3.3 爱好实体Hobby
18.3.4 博客实体Blog
18.3.5 类别实体Category
18.3.6 文章实体Post
18.3.7 登录信息类PersonInfo
18.3.8 persistence.xml
18.4 业务模块设计
18.4.1 DAO层接口
18.4.2 DAO层实现
18.4.3 公共Service层接口
18.4.4 公共Service层实现
18.4.5 用户Service接口
18.5 用户模块
18.5.1 BaseAction基础类
18.5.2 用户注册
18.5.3 struts.xml配置
18.5.4 ApplicationContext.xml配置
18.5.5 web.xml配置
18.5.6 register.jsp
18.5.7 header.jsp,footer.jsp
18.5.8 注册表单验证
18.5.9 异常处理
18.5.10 用户照片文件上传
18.5.11 用户登录注销
18.6 博客模块
18.6.1 开通博客
18.6.2 浏览博客
18.7 类别模块
18.7.1 类别列表
18.7.2 添加类别
18.7.3 浏览类别
18.8 文章模块
18.8.1 列出文章
18.8.2 添加文章
18.8.3 浏览文章
18.9 本章小结
附录一 JPA ORM Annotation 参考
附录二 其他的JPA Annotation参考
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/EJB_JPA/archive/2008/04/18/2304472.aspx
分享到:
相关推荐
EJB+JPA数据库持久层开发实践详解.pdf 完整版
本实践详解主要围绕这两者在数据库持久层的开发应用,帮助开发者深入理解并掌握相关技术。 EJB是Java EE(Enterprise Edition)的一部分,它提供了一种标准的方式来创建可重用的、跨平台的服务器端组件。EJB组件...
### EJB_JPA数据库持久层开发详解 #### JPA与数据持久化技术 **数据持久化**是指将程序运行时的数据保存到永久存储设备中,以便在下次运行时能够读取和使用这些数据。在Java领域,有多种数据持久化技术,包括序列...
EJB.JPA-数据库持久层开发实践详解,感兴趣的人可以阅读一次
**EJB_JPA数据库持久层开发详解** **一、JPA概述** JPA(Java Persistence API)是Java平台上的一个标准,它为Java应用程序提供了一种对象/关系映射工具来管理Java应用中的关系数据。数据持久化是将程序中的对象...
EJB.JPA-数据库持久层开发实践详解.冯曼菲 扫描版带书签
3. **数据持久层**:JPA作为ORM工具,管理拍卖品、用户、出价等对象的数据库映射。当EJB需要操作数据库时,可以通过JPA的API进行,如创建新的拍卖记录,更新最高价,查询用户信息等。 4. **数据库**:存储拍卖系统...
"基于JSF+EJB3+JPA的竞价拍卖系统"是利用Java企业级技术构建的这样一个系统,主要依赖于JavaServer Faces (JSF)、Enterprise JavaBeans 3 (EJB3) 和 Java Persistence API (JPA) 这三大核心技术。下面将详细介绍这三...
6. **DAO(Data Access Object)模式**:虽然不是EJB标准的一部分,但在实际项目中,通常会使用DAO作为持久层和业务层之间的抽象层。DAO封装了对数据库的操作,提供了更清晰的接口,有利于测试和代码复用。 7. **...
【巴巴运动网源码 巴巴运动网 EJB+JPA+SSH】是一个与电子商务相关的项目源码,其中融合了多种技术栈,包括EJB(Enterprise JavaBeans)、JPA(Java Persistence API)以及SSH(Struts + Spring + Hibernate)。...
EJB应用开发详解涵盖了这一技术的各个方面,旨在帮助开发者深入理解和熟练掌握EJB的使用。 **1. EJB概述** EJB是Java EE(Java Platform, Enterprise Edition)的一部分,它提供了一种标准的组件模型,让开发者可以...
Hibernate则作为持久层框架,实现对象关系映射(ORM)。这种组合形成了一个高效且灵活的Web应用程序开发框架。 - **Struts**:作为表现层的一部分,Struts框架提供了丰富的标签库和控制器机制,使得开发者能够轻松...
Java Web JSF + Richfaces + EJB + JPA 航空订票系统是一个综合性的应用,涵盖了多种Java技术,用于构建高效的、可扩展的、易于维护的Web应用程序。在这个系统中,每项技术都有其特定的角色和功能,共同协作以实现...
EJB(Enterprise JavaBeans)是Java企业版(Java EE)的一部分,主要用于构建可扩展、安全且可移植的企业级应用程序。EJB提供了服务器端组件模型,包括会话bean(Session Beans)、实体bean(Entity Beans,现在已被...
**EJB 3.0(Enterprise JavaBeans 3.0)**是Java EE(现在称为Jakarta EE)平台中的一个核心组件,它极大地简化了企业级应用的开发和部署过程。EJB 3.0引入了许多改进,使得开发人员可以更高效地利用面向服务架构...