Title: Container and Bean Managed Persistence
1Entity Beans
- Container and Bean Managed Persistence
2Topics
- Understanding Entity Beans
- Implementing Entity Beans
- Container Managed Persistence
- Bean Managed Persistence
3Understanding Entity Beans
4Enterprise Bean
- Component that can be deployed in any
EJB-compliant application server - Component interface for its operations (Remote
and Local) - Home Interface for create, find, and remove
(Remote and Local) - Bean Implementation
- implements business methods
- implements finder (BMP Entity), home (2.0
Entity), and Select (2.0 CMP Entity) methods
5Bean Types
- Entity Beans
- Represents persistent data in a database
- Account and deposit()
- Exists indefinitely
- Bean-managed and Container-managed persistence
- Session Beans
- Represents business logic operations
- Teller and transfer()
- Stateless and Stateful
- Exist for lifetime of client session
6Bean Types
- Message Beans
- Stateless component invoked using asynchronous
message (JMS)
7Container and Beans
create find
JVM
Container
Remote Home
Remote Home Stub
Remote Client
Remote Object
Remote Object Stub
EJB Class
EJB Class
EJB Class
Local Home
Bean Pool
deposit transfer
Local Client
Local Object
8Entity Bean (from Spec)
- Provides an object view of data in the database
- Allows shared access from multiple users
- Can be long-lived (lives as long as the data in
the database) - The entity, its primary key, and its remote
reference survive the crash of the EJB container
9Entity Bean Support
- Optional in EJB 1.0
- Required in EJB 1.1
- Revised in EJB 2.0
- Added Abstract Schemas
- Added EJB Query Language which is portable across
different database technologies (even though it
is similar to SQL) - Added Container Managed Relationships
- EJB 1.1 support still a requirement in EJB 2.0
10Entity Bean Lifecycle
11Entity Bean States
- Does Not Exist
- no instance instantiated
- default state at container startup
- Pooled
- state entered when container offers component
- state re-entered when object disassociated from
bean - Ready
- state where business methods can be invoked
12Entity Bean Transitions
- Does Not Exist - Pooled
- methods invoked
- Class.newInstance() (default constructor)
- usually not provided/no behavior
- place all bean initialization code in
setEntityContext and object initialization in
ejbCreate/ejbPostCreate - setEntityContext(EntityContext ctx)
- establish EJBs reference to container (ctx)
13Entity Bean Transitions
- Pooled - Ready (via creation)
- occurs when client invokes a Home.create()
- object created, bean instance located
- methods invoked
- ejbCreate()
- may establish properties
- must establish primary key
- object not yet ready to be advertised
- ejbPostCreate()
- establish relationships (object ready to be
advertised)
14Entity Bean Transitions
- Pooled - Ready (via query)
- occurs when Home.find (this.ejbSelect() invoked to return objects
- bean selected from pool, associated with object
- methods invoked
- ejbActivate()
- called after object associated with bean instance
- no transaction or security context
- no interaction with database
15Entity Bean Transitions
- Ready - Pooled (passivation)
- occurs after ejbStore() and just prior to
disassociating object from bean - bean returned to pool
- methods invoked
- ejbPassivate()
- simply a notification
- no state serialized as in Stateful Session Beans
- no interaction with database
16Entity Bean Transitions
- Ready - Pooled (removal)
- occurs when client invokes object.remove()
- bean returned to pool
- methods invoked
- ejbRemove()
- must release any object-specific resources
(identical to ejbPassivate()) - may call ejbPassivate() within ejbRemove()
- called prior to database removal in CMP
- called to remove from database in BMP
17Entity Bean Transitions
- Ready State
- occurs when client invokes object.method()
- bean activated from pool
- methods invoked
- ejbLoad()
- synchronize cache with database (read from
database) - called after db load in CMP command to load in
BMP - business method
- ejbStore()
- synchronize cache with database (write to
database) - called prior to db store in CMP command to store
in BMP
18Implementing CMP Entity Beans
19Creating a Book CMP Entity Bean
- (Create the Primary Key Class)
- if required
- Create Value Objects
- Create the Local/Remote Object Interface
- Entity Beans should only be accessed by Session
Facades through their local interfaces - Create the Local/Remote Home Interface
- Create the Bean Class
- Create the Deployment Descriptors
20Entity Bean Class
container.BookEJB_Impl impls
21EJBContext
22PrimaryKey Class
- Uniquely Identifies Object within database
- Two Objects are considered the same if they have
the same Home and their PrimaryKey objects are
equal - Single primary keys can be mapped to java.lang
classes (e.g. java.lang.String) - Single primary keys may optionally be implemented
with a custom Primary Key Class - Compound primary keys must be implemented with a
custom Primary Key Class
23PrimaryKey Classes
- key values
- must be legal RMI-IIOP types
- must match in type and name with declaration in
the bean class - must be public
- class must implement a Default Constructor,
hashCode() and equals() methods - must be Serializable
24Create the PrimaryKey Class
- package ejava.examples.personnel.ejb20
- import java.io.Serializable
- public class BookPK implements Serializable
- public String id
- public BookPK()
//this one is required - public BookPK(String id) this.id id
//this one is optional - public String toString() return id
- public int hashCode() return
id.hashCode() - public boolean equals(Object rhs)
- try return ((BookPK)rhs).id.equals(id)
- catch (ClassCastException ex) return
false -
25Value Objects
- Used to transfer data between the EJB Tier and
client-tiers - Pass-by-Value semantics
- Also called Data Transfer Objects (DTOs)
- Very similar to structs
- Used by bulk accessors
- bulk accessor interfaces usually declared in
Session Façade Remote
26Create Book Value Objects
- package ejava.examples.ejb.entity
- import java.io.Serializable
- public class Book implements Serializable
- private String id_ private String title_
- private String author_ private String
topic_ - public Book()
- public Book(String id, String title, String
author, String topic) - id_ id title_ title author_
author topic_ topic - public String getId() return id_
- public String getTitle() return
title_ - ...
- public void setTitle(String title) title_
title - ...
27Object Interface
- Defines the business methods to be implemented by
the Bean that can be invoked by a client - Arguments and return types must be legal RMI-IIOP
types - Local Interface
- fine-grain access from Session Façade
- Remote Interface
- larger-grain bulk accessors
28Local Object Interface
- Must extend javax.ejb.EJBLocalObject
- Methods may not throw javax.ejb.RemoteException
- package ejava.examples.ejb.entity.bean
- public interface BookLocal extends
javax.ejb.EJBLocalObject - String getId()
- String getTitle()
- String getAuthor()
- String getTopic()
- void setTitle(String title)
- void setAuthor(String author)
- void setTopic(String topic)
-
29Remote Object Interface
- Must extend javax.ejb.EJBObject
- Methods throw java.rmi.RemoteException
- package ejava.examples.ejb.entity.bean
- import javax.ejb.EJBObject
- import java.rmi.RemoteException
- public interface BookLocal extends EJBObject
- Book getValues() throws RemoteException
- void setValues(Book values) throws
RemoteException -
30Home Interface
- create() and create( args )
- creates row in database
- optional with entity beans
- must have matching ejbCreate() and
ejbPostCreate() methods in bean
implementation if present - find()
- findByPrimaryKey() is
mandatory - other finders can be implemented
- ex. findByName(String firstName, String
lastName) - ex. findByAddress(String address)
- return types include java.util.Collection and
java.util.Set - () - work on table as a whole
31Create Local Home Interface
- package ejava.examples.ejb.entity.bean
- import javax.ejb.EJBLocalHome
- import javax.ejb.CreateException
- import javax.ejb.FinderException
- import java.util.Collection
- public interface BookLocalHome extends
EJBLocalHome - BookLocal create(String id) throws
CreateException - BookLocal create(String id, String title,
String author, String topic) - throws CreateException
- BookLocal findByPrimaryKey(String pk) throws
FinderException - Collection findAll() throws FinderException
32Local Creation Example
- InitialContext jndi new InitialContext()
- BookLocalHome bHome (BookLocalHome)jndi.lookup("
javacomp/env/ejb/BookLocalHome") - BookLocal bookLocal bHome.create(
- book.getId(), book.getTitle(),
book.getAuthor(), book.getTopic())
33Create Remote Home Interface
- package ejava.examples.ejb.entity.bean
- import javax.ejb.EJBHome
- import javax.ejb.CreateException
- import javax.ejb.FinderException
- import java.rmi.RemoteException
- import java.util.Collection
- public interface BookRemoteHome extends EJBHome
- BookRemote create(String id) throws
CreateException, RemoteException - BookRemote create(Book values)
- throws CreateException, RemoteException
- BookRemote findByPrimaryKey(String pk) throws
FinderException - Collection findAll() throws FinderException,
RemoteException
34Remote Creation Example
- InitialContext jndi new InitialContext()
- BookRemoteHome bHome (BookRemoteHome)jndi.lookup
("javacomp/env/ejb/BookRemoteHome") - BookRemote bookRemote bHome.create(book)
35Create the Bean Class
- package ejava.examples.ejb.entity.bean
- import javax.ejb.EntityBean
- import javax.ejb.EntityContext
- public abstract class BookEJB implements
EntityBean - / This is our reference into the container.
/ - private EntityContext ctx_
-
36Define the Abstract Accessors
- public abstract void setId(String id)
- public abstract String getId()
- public abstract void setAuthor(String author)
- public abstract String getAuthor()
- public abstract void setTitle(String title)
- public abstract String getTitle()
- public abstract void setTopic(String topic)
- public abstract String getTopic()
37Implement the Bean Class Business Methods
- public Book getValues()
- return new Book(getId(), getTitle(),
getAuthor(), getTopic()) -
- public void setValues(Book values)
- setTitle(values.getTitle())
- setAuthor(values.getAuthor())
- setTopic(values.getTopic())
-
- Real business methods would be much more
complicated
38Coordinate Access to Container
- / This method is invoked after the bean
class is instantiated and just - prior to being available in the pool. The
bean should acquire any - object-neutral resources at this point.
Note that the bean is not - associated with an object at this point and
any calls to the - context's getPrimaryKey() will result in an
exception. / - public void setEntityContext(EntityContext
ctx) ctx_ ctx - / This method is invoked just after removing
the bean from the pool and - finalizing it. The bean should release any
object-neural resources at - this point. Note that the bean is not
associated with an object at - this point and any attempt to access the
primary key or abstract data - model will result in an error. /
- public void unsetEntityContext() ctx_
null
39Implement Bean ClassCreate Methods
- /
- This method must set the primary key for the
object and optionally - set any of the fields that will get mapped
into the database. / - public String ejbCreate(String id)
- setId(id)
- return null //container gets primary key
another way -
- /
- This method is where we establish any
relationships to our object. / - public void ejbPostCreate(String id)
40Implement Bean ClassCreate Methods (cont.)
- public String ejbCreate(String id, String title,
String author, String topic) - setId(id)
- setTitle(title)
- setAuthor(author)
- setTopic(topic)
- return null //container gets primary key
another way -
- public void ejbPostCreate(
- String id, String title, String author, String
topic) -
41Implement Bean ClassRemove Method
- /
- This method is called just before the row(s)
representing the - abstract data model get removed from the
database. - /
- public void ejbRemove()
- log("BookEJB.ejbRemove" getId() ""
getTitle())
42Implement Bean ClassResource Management Methods
- / This method is invoked just after the bean is
associated with an - object. We have a primary key, but out
abstract data model has not - yet been synchronized with the database. We
can allocate any - object-specific resources (that do not depend
on the database values) - at this point. /
- public void ejbActivate()
- / This method is invoked just prior to
disassociating the object from - the bean. The state of the abstract data model
has already been - synchronized with the database. We should
release any object-specific - resources as this point. /
- public void ejbPassivate()
43Implement Bean ClassDatabase Synchronization
Methods
- /
- This method is called just after the abstract
data model has been - restored from the database. This method should
prepare any transient - variables for use by the business methods as
this time. / - public void ejbLoad()
- /
- This method is called just before the abstract
data model gets stored - to the database. This method should prepare
the abstract data model - variables for their stored state. /
- public void ejbStore()
44Create Deployment Descriptor(ejb-jar.xml)
- Inc.//DTD Enterprise JavaBeans 2.0//EN'
'http//java.sun.com/dtd/ejb-jar_2_0.dtd' -
-
-
- Book
- ...
-
-
-
-
- ...
-
-
45Define the Individual Beans
-
- Book
- ejava.examples.ejb.entity.bean.BookRem
oteHome - ejava.examples.ejb.entity.bean.BookR
emote - ejava.examples.ejb.entity.bean.B
ookLocalHome - ejava.examples.ejb.entity.bean.BookLo
cal - ejava.examples.ejb.entity.bean.Bo
okEJB -
46Define the Primary Key Class
- Containere
- java.lang.Stringlass
- False
47Define the Container ManagedFields (CMP)
- Book
-
- author
-
-
- id
-
-
- title
-
-
- topic
-
- id
48Define Environment Properties
-
-
- This is a sample env
entry. - example
- java.lang.Stringype
- Sample Environment
Value -
49Define EJB References
-
-
- Session or
Entity -
-
-
-
-
-
- Session or
Entity -
-
-
-
50Define Queries CMP Queries
-
-
- findAll
-
-
-
- SELECT OBJECT(b) FROM Book b
-
51Define Client Jar File
52Things We Skipped (coming)
- Defining Security Roles
- Defining Security Access
- Defining Transaction Scope
53Defining Database-Specific Mapping(weblogic-cmp-r
dbms-jar.xml)
- Systems, Inc.//DTD WebLogic 6.0.0 EJB RDBMS
Persistence//EN' 'http//www.bea.com/servers/wls60
0/dtd/weblogic-rdbms20-persistence-600.dtd' -
-
- Book
- ejava.jdbc.txDataSourcea-source-name
- Book
-
- ...
-
-
- True-dbms-tables
54Map Columns to Fields(weblogic-cmp-rdbms-jar.xml)
-
- author
- author
-
-
- id
- id
-
-
- title
- title
-
-
- topic
- topic
-
-
55Map Container-Specific Resources(weblogic-ejb-jar
.xml)
- Systems, Inc.//DTD WebLogic 6.0.0 EJB//EN'
'http//www.bea.com/servers/wls600/dtd/weblogic-ej
b-jar.dtd' -
-
- Book
-
- ...
-
- ejava/examples/ejb/entity/Boo
kLocalHome -
-
56Map Container-Specific Resources(weblogic-ejb-jar
.xml)
-
-
-
- WebLogic_CMP_RDBMSe-identifier
- 6.0
- META-INF/weblogic-cmp-rdbm
s-jar.xml -
-
- WebLogic_CMP_RDBMSe-identifier
- 6.0
-
-
-
57Database Synchronization
- As with all EJBs, only a single thread can be
running within a bean instance - Multiple entity bean instances can be created to
represent same data in database - Consistency ?
- ejbLoad() and ejbStore() are called to
synchronize bean with underlying storage
58State Management
- State synchronization methods
- ejbLoad
- ejbStore
- Resource Management methods
- ejbActivate
- ejbPassivate
59Entity Bean Types
- Bean can have total control over loading and
storing from database - Bean Managed Persistence (BMP)
- Container can take over this responsibility
- Container Managed Persistence (CMP)
- Specialized Implementations
- Toplink for relational databases
- CICS
60CMP Summary
- Eliminates a lot of code
- less code means fewer bugs
- Provides support for relationships (covered
later) - Provides support for database-generic queries
(EJB-QL covered later) - Problems
- abstract model based on Java database
implementations do not always map Java constructs
the same - many containers can only map a bean to one table
61Bean Managed Persistence
62Bean Managed Persistence (BMP)
- The CustomerBean used BMP
- implemented all database interaction
- create, remove, and find
- Have to do object-relational mapping
- Synchronize bean state with database when
requested by container
63Activation and Passivation
- When Passivated, bean should give up any
resources held on behalf of the data represented
by the Primary Key - When Activated, bean can acquire and resources
specific to the Primary Key
64BMP Summary
- Have to handle all database interaction
- except transactions
- ejbLoad() and ejbStore() called when bean
instance state must be synchronized with database - ejbActivate() and ejbPassivate() called when bean
is moved between the ready state and pooled state
65Implement a BMP Entity Bean
- package ejava.examples.ejb.entity.bean
- import javax.ejb.EntityBean
- import javax.ejb.EntityContext
-
- public class BookBMP extends BookEJB
- private DataSource dataSource_
- private EntityContext ctx_
66Implement the Abstract Data Model
- private String id_
- private String title_
- private String author_
- private String topic_
- public void setId(String id)
id_ id - public String getId()
return id_ - public void setAuthor(String author)
author_ author - public String getAuthor()
return author_ - public void setTitle(String title)
title_ title - public String getTitle()
return title_ - public void setTopic(String topic)
topic_ topic - public String getTopic()
return topic_
67Locate the Database
- public void setEntityContext(EntityContext ctx)
- super.setEntityContext(ctx)
- ctx_ ctx
- InitialContext jndi null
- try
- jndi new InitialContext()
- dataSource_ (DataSource)jndi.lookup("java
comp/env/jdbc/mydb") -
- catch (NamingException ex)
- throw new EJBException(ex)
-
- finally
- try if (jndi!null) jndi.close() catch
(Exception e) -
-
68Implement DB Insertion
- public String ejbCreate(String id, String title,
String author, String topic) - super.ejbCreate(id, title, author, topic)
- Connection conn null
PreparedStatement pstatement null - try
- conn dataSource_.getConnection()
- pstatementconn.prepareStatement("insert
into Book (id, title, author, topic)" - values (?, ?, ?, ?)")
- pstatement.setString(1,id_)
pstatement.setString(2,title_) - pstatement.setString(3,author_)
pstatement.setString(4,topic_) - pstatement.execute()
return id_ -
- catch(SQLException ex) throw new
EJBException(ex) - finally
-
69Implement PostCreate
- public void ejbPostCreate(
- String id, String title, String author, String
topic) - super.ejbPostCreate(id, title, author, topic)
-
70Implement DB Load
- public void ejbLoad()
- Connection conn null
- PreparedStatement pstatement null
- ResultSet rs null
- try
- conn dataSource_.getConnection()
- pstatement conn.prepareStatement(
- "select id, title, author, topic from
Book " "where id ?") - pstatement.setString(1, (String)ctx_.getPrim
aryKey()) - rs pstatement.executeQuery()
- if (rs.next())
- ...
71Implement DB Load (cont.)
- if (rs.next())
- id_ rs.getString("id") title_
rs.getString("title") - author_ rs.getString("author")
topic_ rs.getString("topic") - super.ejbLoad()
-
- else
- throw new EJBException("unable to locate
row") -
-
- catch(SQLException ex)
- throw new EJBException(getText(ex))
-
- finally
72Implement DB Store
- public void ejbStore()
- Connection conn null PreparedStatement
pstatement null - try
- super.ejbStore()
- conn dataSource_.getConnection()
- pstatement conn.prepareStatement(
- "update Book set title?, author?,
topic? " "where id ?") - pstatement.setString(1,title_)
pstatement.setString(2,author_) - pstatement.setString(3,topic_)
pstatement.setString(4,id_) - pstatement.executeUpdate()
-
- catch(SQLException ex) throw new
EJBException(getText(ex)) - finally
-
73Implement DB Remove
- public void ejbRemove()
- Connection conn null
- PreparedStatement pstatement null
- try
- super.ejbRemove()
- conn dataSource_.getConnection()
- pstatement conn.prepareStatement("delete
from Book " "where id ?") - pstatement.setString(1, (String)ctx_.getPrim
aryKey()) - pstatement.executeUpdate()
-
- catch(SQLException ex) throw new
EJBException(getText(ex)) - finally
-
74Implement Finders
- public String ejbFindByPrimaryKey(String pk)
throws FinderException - Connection conn null
PreparedStatement pstatement null - ResultSet rs null
- try
- conn dataSource_.getConnection()
- pstatement conn.prepareStatement("select
id from Book " "where id ?") - pstatement.setString(1, pk)
- rs pstatement.executeQuery()
- if (rs.next()) return rs.getString("id")
- else throw new ObjectNotFoundException(pk
" no found") -
- catch(SQLException ex) throw new
EJBException(getText(ex)) - finally ...
-
75Implement Finders (cont.)
- public Collection ejbFindAll() throws
FinderException - Connection conn null
- PreparedStatement pstatement null
- ResultSet rs null
- try
- Vector pKeys new Vector()
- conn dataSource_.getConnection()
- pstatement conn.prepareStatement("select
id from Book ") - rs pstatement.executeQuery()
- while (rs.next())
pKeys.add(rs.getString("id")) - return pKeys
-
- catch(SQLException ex) throw new
EJBException(getText(ex)) - finally ...
-
76Configure Deployment Descriptors(ejb-jar.xml)
-
- BookBMP
- ejava.examples.ejb.entity.bean.BookL
ocalHome - ejava.examples.ejb.entity.bean.BookLocal/local
- ejava.examples.ejb.entity.bean.BookBM
P - Bean
- java.lang.String
- False
-
- jdbc/mydb
- javax.sql.DataSource
- Container
-
-
77Configure Deployment Descriptors(weblogic-ejb-jar
.xml)
-
- BookBMP
-
-
- jdbc/mydb
- ejava.jdbc.txDataSourcee
-
-
- ejava/examples/ejb/entity/BMPBo
okLocalHome -
78Entity Bean Performance Issues
79Performance Issues
- When could Entity Beans be expensive
- CMP performs eager database synchronization on
each transaction - BMP allows for lazy database synchronization
- Who should call the Entity Beans Remote methods
? - Should you utilize entity beans at all ?
- Performance hit - all calls go through the
container via the EJBObject - Higher performance going directly to the
databases vs. functionality of container
80Entity Bean Summary
- Models persistent state in database
- Facilitates declarative persistence
- BMP vs. CMP
- Performance implications
- wrap calls to entity beans with session beans