使用 Apache OpenJPA 开发 EJB 3.0 应用,第 4 部分: 实体关联
2010-04-19 00:00:00 来源:WEB开发网产生的 SQL 语句
下面的这段 SQL 语句是运行上面的代码时 OpenJPA 自动生成的,我们可以从中看到 OpenJPA 级联新建对象时的处理过程:
-- 创建 Book 实体对应的数据库表 --
CREATE TABLE Book (ID INTEGER NOT NULL AUTO_INCREMENT, NME VARCHAR(255),
extendID INTEGER, PRIMARY KEY (ID));
-- 创建 BookExtend 实体对应数据库表 --
CREATE TABLE BookExtend (ID INTEGER NOT NULL AUTO_INCREMET,
NAME VARCHAR(255), PRIMARY KEY (ID)) ;
-- 将 Book 实体对象插入数据库中 --
INSERT INTO Book (NAME) VALUES (‘<<Web Services实践>>’)
-- 获取 Book 实体对象的编号 --
SELECT LAST_INSERT_ID();
-- 将 BookExtend 实体对象插入数据库中 --
INSERT INTO BookExtend (NAME) VALUES (‘前言 本书重点说明了...’) ;
--获取 BookExtend 实体对象的编号 --
SELECT LAST_INSERT_ID();
-- 将 BookExtend 实体对象的编号更新到Book表中形成关联关系 --
UPDATE Book SET extendID = 1 WHERE ID = 1;
级联更新对象状态
下面的这段代码演示了只需要调用 Book 类的 merge 方法就同时更新 Book 类对象和 BookExtend 类对象状态的情况。请注意其中用粗体标识出的部分。
/* 获得 EJB 的实体管理器 */
EntityManagerFactory emf = Persistence.createEntityManagerFactory(null);
EntityManager em = emf.createEntityManager(PersistenceContextType.EXTENDED);
/* 开始事务 */
em.getTransaction().begin();
/* 创建新的 Book 对象 */
Book book = new Book();
/* 设置 Book 对象的 id 属性 */
book.id= 1;
book.name = “OpenJPA入门”;
/* 创建新的 BookExtend 对象 */
BookExtend bookExtend = new BookExtend();
/* 设置对象属性 */
bookExtend.id=1;
bookExtend.name = "OpenJPA开发EJB3.0应用 ...";
/* 建立对象之间的关系 */
book.bookExtend = bookExtend;
/* 持久化对象,只需要调用 Book 对象的 merge 方法,不需要单独处理 bookExtend 对象 */
em.merge(book);
/* 结束事务 */
em.getTransaction().commit();
em.close();
emf.close();
- ››使用linux中的quota教程
- ››apache设置域名绑定 以及绑定不起作用的排查
- ››使用jxl生成带动态折线图的excel
- ››apache rewrite将指定URL转向指定的几个服务器
- ››使用mysql mysqldump进行数据库迁移
- ››使用jquery是新tab形式
- ››使用QUnit进行Javascript单元测试
- ››使用UITextFieldDelegate来隐藏键盘
- ››使用公式提取Excel中的日期后发现格式不对
- ››使用SQL Azure 的BI 解决方案
- ››使用PLSQL Developer工具导出sql文件
- ››使用双缓冲技术实现Android画板应用
更多精彩
赞助商链接