站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Eclipse 专题Eclipse快速上手EJB -- 5. 一对多的双向关系的CMR(1)

Eclipse快速上手EJB -- 5. 一对多的双向关系的CMR(1)

摘要: Eclipse快速上手EJB -- 5. 一对多的双向关系的CMR(1)
这个系列文章我是根据 Rick Hightower 发表在 IBM 网站的文章 《EJB - CMP/CMR 介绍》 改编而成的,这是一个系列,共有4篇文章。这篇文章综合了那4篇文章,看这篇文章前一定要参考一下,这样理解起来很方便,不过我做了部分修改,原理基本还是不变的。关于 CMP 方面的知识我不说了,我这里只是介绍如何使用 Lomboz 和 JBoss-IDE 在Eclipse 中开发 CMP。 这篇文章主要讲述如何开发一对多的双向联系,这里设计了一个GroupBean,和UserInfoBean建立联系(注意,IBM 网站的文章是和UserBean建立联系,这里我认为和UserInfoBean建立联系更合适)。重点放在如何使用XDoclet建立一对多的双向联系,客户端的调用比较简单。 这篇文章是由 《Eclipse快速上手EJB -- 2. 设计一个实体Bean》、《Eclipse快速上手EJB -- 3. 设计一对一的双向关系的CMR(1)》 《Eclipse快速上手EJB -- 4. 多对多的单向关系的CMR(1) 》延伸而来。所以,必须要有这三篇文章的基础才行。 关于环境配置、使用技巧还是要参考我以前的文章,这里尽量省略。 一、设计实体Bean :GroupBean
1. 建立主体部分: 在 CMP_Sample 项目中,右击“src” ->新建 ->Lomboz EJB Creation Wizard : · 包(K) :javamxj.ejb.cmp · 名称(M): Group · EJB Type: 选择 Container Managed Entity EJB 点击下一步。 ● Schema Name: GroupSchema Table Name: GroupTable
增加一个 name 栏:
· Field: name · Field Type: java.lang.String · Database Column: 名称 · SQL Type: varchar
并且使它成为主键
同样,再增加一个 description 栏:
· Field: description · Field Type: java.lang.String · Database Column: 行业说明 · SQL Type: varchar 效果如下,最后点击完成。 注意:如上篇文章一样,将生成代码中的 sql-type="varchar" 改写成 sql-type="varchar(xy)" ,xy是一个合适的VARCHAR 的位数。 2. 完成 ejbCreate 和 ejbPostCreate 方法: 3. 在类标记中加入以下标记: 4. 增加一个Select method ,你可以使用JBoss-IDE得到,这里是代码(后面有完整的源代码): //######################## Select method ##############################
/**
* Select method
* @ejb.select
* query = "SELECT user.email FROM GroupSchema AS g, IN (g.users) AS user WHERE g.name = ?1"
*
*/
public abstract java.util.Collection ejbSelectUserIDs(String groupName)
throws javax.ejb.FinderException;

/**
* Home method
* @throws FinderException
* @ejb.home-method view-type = "local"
*/
public java.util.ArrayList ejbHomeGetUserIDs(String groupName)
throws javax.ejb.FinderException {
return (java.util.ArrayList) ejbSelectUserIDs(groupName);
}

5. 将 GroupBean 加入到 cmpEJB 模块中,然后 lomboz ->Generate EJB Classes 6. 重点:建立 GroupBean 与 UserInfoBean 的一对多的双向联系: 右击 GroupBean ->J2EE ->Add CMR Relationship : 生成的代码参考下面给出的完整的源代码。
切换到 UserInfoBean.java
右击 UserInfoBean ->J2EE ->Add CMR Relationship : 在 UserInfoBean.java 中生成的代码(需要手工添加@jboss.relation):
/**
* Getter for CMR Relationship
*
* @ejb.interface-method view-type="local"
* @ejb.relation name = "GroupsHaveUserInfos"
* role-name = "UserInfosInGroup"
* target-multiple = "yes"
* @jboss.relation
* fk-column = "组别"
* related-pk-field = "name"
*/
public abstract javamxj.ejb.cmp.GroupLocal getGroup();

/**
* Setter for CMR Relationship
*
* @ejb.interface-method view-type="local"
*/
public abstract void setGroup(javamxj.ejb.cmp.GroupLocal value);

Ok,再次 Generate EJB Classes ,如果一切正常,再进行下一步。
下面给出了GroupBean.java的完整的源代码:

GroupBean.java

/*

 * 创建日期 2005-1-26

 *

 * 作者:javamxj(分享java快乐)

 */

package javamxj.ejb.cmp;

/**

 *

 *

 <?xml version="1.0" encoding="UTF-8"?>

 

 

 

 Group

 Group

 javamxj.ejb.cmp.GroupBean

 Container

 java.lang.String

 2.x

 GroupSchema

 name

 

 

 name

 java.lang.String

 名称

 VARCHAR

 varchar

 false

 true

 

 

 description

 java.lang.String

 行业说明

 VARCHAR

 varchar

 false

 false

 

 GroupTable

 

 

 

 *

 *

 * @ejb.bean name="Group"

 * jndi-name="Group"

 * type="CMP"

 *  primkey-field="name"

 *  schema="GroupSchema"

 *  cmp-version="2.x"

 *  view-type = "local"

 *  data-source=""

 *

 *  @ejb.persistence

 *   table-name="GroupTable"

 *

 *

 *

 * @ejb.finder

 *    query="SELECT OBJECT(a) FROM GroupSchema as a" 

 *    signature="java.util.Collection findAll()" 

 *

 * @ejb.pk class="java.lang.String"

 *

 * @generated

 **/

public abstract class GroupBean implements javax.ejb.EntityBean {

 /**

  * @ejb.create-method

  */

 public java.lang.String ejbCreate(String name, String description)

  throws javax.ejb.CreateException {

  // EJB 2.0 spec says return null for CMP ejbCreate methods.

  setName(name);

  setDescription(description);

  return null;

 }

 /**

  * The container invokes this method immediately after it calls ejbCreate.

  */

 public void ejbPostCreate(String name, String description)

  throws javax.ejb.CreateException {

 }

 /**

  * CMP Field name

  * @return the name

  * @ejb.persistent-field

  * @ejb.persistence

  *    column-name="名称"

  *     jdbc-type="VARCHAR"

  *     sql-type="varchar(24)"

  *     read-only="false"

  * @ejb.pk-field

  *

  * @ejb.interface-method

  */

 public abstract java.lang.String getName();

 /**

  * @param java.lang.String the new name value

  * @ejb.interface-method

  */

 public abstract void setName(java.lang.String name);

 /**

  * CMP Field description

  * @return the description

  * @ejb.persistent-field

  * @ejb.persistence

  *    column-name="行业说明"

  *     jdbc-type="VARCHAR"

  *     sql-type="varchar(24)"

  *     read-only="false"

  * 

  *

  * @ejb.interface-method

  */

 public abstract java.lang.String getDescription();

 /**

  * @param java.lang.String the new description value

  * @ejb.interface-method

  */

 public abstract void setDescription(java.lang.String description);

 //########################   Select method     ##############################

 /**

  * Select method

  * @ejb.select

  *    query = "SELECT user.email  FROM GroupSchema AS g, IN (g.users) AS user  WHERE g.name = ?1"

  *             

  */

 public abstract java.util.Collection ejbSelectUserIDs(String groupName)

  throws javax.ejb.FinderException;

 /**

  * Home method

  * @throws FinderException

  * @ejb.home-method  view-type = "local"

  */

 public java.util.ArrayList ejbHomeGetUserIDs(String groupName)

  throws javax.ejb.FinderException {

  return (java.util.ArrayList) ejbSelectUserIDs(groupName);

 }

// ########################   CMR Relationship     ##############################

 /**

  * Getter for CMR Relationship

  *

  * @ejb.interface-method   view-type="local"

  * @ejb.relation           name = "GroupsHaveUserInfos"

  *                         role-name = "GroupHasUserInfos"

  *                         target-multiple = "no"

  */

 public abstract java.util.Collection getUsers();

 /**

  * Setter for CMR Relationship

  *

  * @ejb.interface-method   view-type="local"

  */

 public abstract void setUsers(java.util.Collection value);

}



↑返回目录
前一篇: Eclipse快速上手EJB -- 5. 一对多的双向关系的CMR(2)
后一篇: 在Eclipse3.0.x配置基于STRUTS的WEB开发环境