The PlayerBean Code
The
PlayerBeanentity bean represents a player in a sports league. Like any local entity bean with container-managed persistence,PlayerBeanneeds the following code:The source code for this example is in the
<INSTALL>/j2eetutorial14/examples/ejb/cmprosterdirectory.Entity Bean Class
The code of the entity bean class must meet the container-managed persistence syntax requirements. First, the class must be defined as
publicandabstract. Second, the class must implement the following:The entity bean class must not implement these methods:
Differences between Container-Managed and Bean-Managed Code
Because it contains no calls to access the database, an entity bean with container-managed persistence requires a lot less code than one with bean-managed persistence. For example, the
PlayerBean.javasource file discussed in this chapter is much smaller than theSavingsAccountBean.javacode documented in Chapter 26. Table 27-1 compares the code of the two types of entity beans.
Note that for both types of persistence, the rules for implementing business and home methods are the same. See the sections The Business Methods and The Home Methods in Chapter 26.
Access Methods
An entity bean with container-managed persistence has persistent and relationship fields. These fields are virtual, so you do not code them in the class as instance variables. Instead, you specify them in the bean's deployment descriptor. To permit access to the fields, you define abstract
getandsetmethods in the entity bean class.Access Methods for Persistent Fields
The EJB container automatically performs the database storage and retrieval of the bean's persistent fields. The deployment descriptor of
PlayerBeanspecifies the following persistent fields:The
PlayerBeanclass defines the access methods for the persistent fields as follows:public abstract String getPlayerId(); public abstract void setPlayerId(String id); public abstract String getName(); public abstract void setName(String name); public abstract String getPosition(); public abstract void setPosition(String position); public abstract double getSalary(); public abstract void setSalary(double salary);The name of an access method begins with
getorset, followed by the capitalized name of the persistent or relationship field. For example, the accessor methods for thesalaryfield aregetSalaryandsetSalary. This naming convention is similar to that of JavaBeans components.Access Methods for Relationship Fields
In the
RosterAppapplication, a player can belong to multiple teams, so aPlayerBeaninstance may be related to manyTeamBeaninstances. To specify this relationship, the deployment descriptor ofPlayerBeandefines a relationship field namedteams. In thePlayerBeanclass, the access methods for theteamsrelationship field are as follows:Finder and Select Methods
Finder and select methods use EJB QL queries to return objects and state information of entity beans using container-managed persistence.
A select method is similar to a finder method in the following ways:
However, a select method differs significantly from a finder method:
- A select method can return a persistent field (or a collection thereof) of a related entity bean. A finder method can return only a local or remote interface (or a collection of interfaces).
- Because it is not exposed in any of the local or remote interfaces, a select method cannot be invoked by a client. It can be invoked only by the methods implemented within the entity bean class. A select method is usually invoked by either a business or a home method.
- A select method is defined in the entity bean class. For bean-managed persistence, a finder method is defined in the entity bean class, but for container-managed persistence it is not.
The
PlayerBeanclass defines these select methods:public abstract Collection ejbSelectLeagues(LocalPlayer player) throws FinderException; public abstract Collection ejbSelectSports(LocalPlayer player) throws FinderException;The signature for a select method must follow these rules:
Business Methods
Because clients cannot invoke select methods, the
PlayerBeanclass wraps them in thegetLeaguesandgetSportsbusiness methods:public Collection getLeagues() throws FinderException { LocalPlayer player = (team.LocalPlayer)context.getEJBLocalObject(); return ejbSelectLeagues(player); } public Collection getSports() throws FinderException { LocalPlayer player = (team.LocalPlayer)context.getEJBLocalObject(); return ejbSelectSports(player); }Entity Bean Methods
Because the container handles persistence, the life-cycle methods in the
PlayerBeanclass are nearly empty.The
ejbCreatemethod initializes the bean instance by assigning the input arguments to the persistent fields. At the end of the transaction that contains the create call, the container inserts a row into the database. Here is the source code for theejbCreatemethod:public String ejbCreate (String id, String name, String position, double salary) throws CreateException { setPlayerId(id); setName(name); setPosition(position); setSalary(salary); return null; }The
ejbPostCreatemethod returnsvoid, and it has the same input parameters as theejbCreatemethod. If you want to set a relationship field to initialize the bean instance, you should do so in theejbPostCreatemethod. You cannot set a relationship field in theejbCreatemethod.Except for a debug statement, the
ejbRemovemethod in thePlayerBeanclass is empty. The container invokesejbRemovebefore removing the entity object.The container automatically synchronizes the state of the entity bean with the database. After the container loads the bean's state from the database, it invokes the
ejbLoadmethod. In like manner, before storing the state in the database, the container invokes theejbStoremethod.Local Home Interface
The local home interface defines the
create, finder, and home methods that can be invoked by local clients.The syntax rules for a
createmethod follow:
- The name must begin with
create.- It must have the same number and types of arguments as its matching
ejbCreatemethod in the entity bean class.- It must return the local interface type of the entity bean.
- The
throwsclause must include the exceptions specified by thethrowsclause of the correspondingejbCreatemethod.- The
throwsclause must contain thejavax.ejb.CreateException.These rules apply for a finder method:
An excerpt of the
LocalPlayerHomeinterface follows.package team; import java.util.*; import javax.ejb.*; public interface LocalPlayerHome extends EJBLocalHome { public LocalPlayer create (String id, String name, String position, double salary) throws CreateException; public LocalPlayer findByPrimaryKey (String id) throws FinderException; public Collection findByPosition(String position) throws FinderException; ... public Collection findByLeague(LocalLeague league) throws FinderException; ... }Local Interface
This interface defines the business and access methods that a local client can invoke. The
PlayerBeanclass implements two business methods:getLeaguesandgetSports. It also defines severalgetandsetaccess methods for the persistent and relationship fields. Thesetmethods are hidden from the bean's clients because they are not defined in theLocalPlayerinterface. However, thegetmethods are exposed to the clients by the interface:package team; import java.util.*; import javax.ejb.*; public interface LocalPlayer extends EJBLocalObject { public String getPlayerId(); public String getName(); public String getPosition(); public double getSalary(); public Collection getTeams(); public Collection getLeagues() throws FinderException; public Collection getSports() throws FinderException; }