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

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

Eclipse快速上手EJB -- 4. 多对多的单向关系的CMR(1)

摘要: Eclipse快速上手EJB -- 4. 多对多的单向关系的CMR(1)
这个系列文章我是根据 Rick Hightower 发表在 IBM 网站的文章 《EJB - CMP/CMR 介绍》 改编而成的,这是一个系列,共有4篇文章。这篇文章综合了那4篇文章,看这篇文章前一定要参考一下,这样理解起来很方便,不过我做了部分修改,原理基本还是不变的。关于 CMP 方面的知识我不说了,我这里只是介绍如何使用 Lomboz 和 JBoss-IDE 在Eclipse 中开发 CMP。 这篇文章主要讲述如何开发多对多的单向联系,这里设计了一个RoleBean,和UserBean建立联系,由UserBean控制RoleBean。重点放在如何使用XDoclet建立多对多的单向联系,客户端的调用比较简单。 这篇文章是由 《Eclipse快速上手EJB -- 2. 设计一个实体Bean》、《Eclipse快速上手EJB -- 3. 设计一对一的双向关系的CMR(1)》延伸而来。所以,必须要有这两篇文章的基础才行 关于环境配置、使用技巧还是要参考我以前的文章,这里尽量省略。 一、设计实体Bean :RoleBean
1. 建立主体部分: 在 CMP_Sample 项目中,右击“src” ->新建 ->Lomboz EJB Creation Wizard : · 包(K) :javamxj.ejb.cmp · 名称(M): Role · EJB Type: 选择 Container Managed Entity EJB 点击下一步。 ● Schema Name: RoleSchema Table Name: RoleTable
增加一个 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. 在类标记中加入以下标记: 下面给出了RoleBean.java的完整的源代码:

RoleBean.java

/*

 * 创建日期 2005-1-25

 *

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

 */

package javamxj.ejb.cmp;

/**

 *

 *

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

 

 

 

 Role

 Role

 javamxj.ejb.cmp.RoleBean

 Container

 java.lang.String

 2.x

 RoleSchema

 name

 

 

 name

 java.lang.String

 权限名称

 VARCHAR

 varchar

 false

 true

 

 

 description

 java.lang.String

 权限描述

 VARCHAR

 varchar

 false

 false

 

 RoleTable

 

 

 

 *

 *

 * @ejb.bean name="Role"

 * jndi-name="Role"

 * type="CMP"

 *  primkey-field="name"

 *  schema="RoleSchema"

 *  cmp-version="2.x"

 *  view-type = "local"

 *  data-source=""

 *

 *  @ejb.persistence

 *   table-name="RoleTable"

 * 

 *  @jboss.persistence

 *    create-table = "true"

 *    remove-table = "false"

 *

 * @ejb.finder

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

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

 *

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

 *

 * @generated

 **/

public abstract class RoleBean 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(12)"

   *     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(30)"

   *     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);

}

好了,保存,将 RoleBean 加入到 cmpEJB 模块中,然后 lomboz ->Generate EJB Classes4. 重点:建立 UserBean 对 RoleBean 的多对多的单向联系: · 由于这次设计的是UserBean对RoleBean的单向联系,所以只需要在UserBean中添加方法标记即可。 切换到 UserBean.java ,右击 UserBean ->J2EE ->Add CMR Relationship : · 生成的标记如下,还需要手工添加一些@JBoss标记: · 保存,Generate EJB Classes


↑返回目录
前一篇: Eclipse入门—使用指南及开发Eclipse插件
后一篇: Eclipse快速上手EJB -- 3. 一对一的双向关系的CMR(2)