WEB开发网
开发学院软件开发Java 使用 Apache OpenJPA 开发 EJB 3.0 应用,第 4 部... 阅读

使用 Apache OpenJPA 开发 EJB 3.0 应用,第 4 部分: 实体关联

 2010-04-19 00:00:00 来源:WEB开发网   
核心提示: 产生的 SQL 语句 下面的这段 SQL 语句是运行上面的代码时 OpenJPA 自动生成的,我们可以从中看到 OpenJPA 级联新建对象时的处理过程:--创建Book实体对应的数据库表--CREATETABLEBook(IDINTEGERNOTNULLAUTO_INCREMENT,NMEVA

产生的 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(); 

上一页  4 5 6 7 8 9 10  下一页

Tags:使用 Apache OpenJPA

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接