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

19 篇文章 0 订阅
16 篇文章 0 订阅
   这个系列文章我是根据 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; /**  *  * <!-- begin-user-doc --> You can insert your documentation for '<em><b>RoleBean</b></em>'. <!-- end-user-doc --> *  <!--  begin-lomboz-definition -->  <?xml version="1.0" encoding="UTF-8"?>  <lomboz:EJB xmlns:j2ee="http://java.sun.com/xml/ns/j2ee" xmlns:lomboz="http://lomboz.objectlearn.com/xml/lomboz">  <lomboz:entity>  <lomboz:entityEjb>  <j2ee:display-name>Role</j2ee:display-name>  <j2ee:ejb-name>Role</j2ee:ejb-name>  <j2ee:ejb-class>javamxj.ejb.cmp.RoleBean</j2ee:ejb-class>  <j2ee:persistence-type>Container</j2ee:persistence-type>  <j2ee:prim-key-class>java.lang.String</j2ee:prim-key-class>  <j2ee:cmp-version>2.x</j2ee:cmp-version>  <j2ee:abstract-schema-name>RoleSchema</j2ee:abstract-schema-name>  <j2ee:primkey-field>name</j2ee:primkey-field>  </lomboz:entityEjb>  <lomboz:fieldMappings>  <lomboz:fieldName>name</lomboz:fieldName>  <lomboz:fieldType>java.lang.String</lomboz:fieldType>  <lomboz:columnName>权限名称</lomboz:columnName>  <lomboz:jdbcType>VARCHAR</lomboz:jdbcType>  <lomboz:sqlType>varchar</lomboz:sqlType>  <lomboz:readOnly>false</lomboz:readOnly>  <lomboz:primaryKey>true</lomboz:primaryKey>  </lomboz:fieldMappings>  <lomboz:fieldMappings>  <lomboz:fieldName>description</lomboz:fieldName>  <lomboz:fieldType>java.lang.String</lomboz:fieldType>  <lomboz:columnName>权限描述</lomboz:columnName>  <lomboz:jdbcType>VARCHAR</lomboz:jdbcType>  <lomboz:sqlType>varchar</lomboz:sqlType>  <lomboz:readOnly>false</lomboz:readOnly>  <lomboz:primaryKey>false</lomboz:primaryKey>  </lomboz:fieldMappings>  <lomboz:tableName>RoleTable</lomboz:tableName>  <lomboz:dataSourceName></lomboz:dataSourceName>  </lomboz:entity>  </lomboz:EJB>  <!--  end-lomboz-definition -->  *  * <!-- begin-xdoclet-definition -->  * @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"  * <!-- end-xdoclet-definition -->  * @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 Classes
 
 
4. 重点:建立 UserBean 对 RoleBean 的多对多的单向联系:
 
·   由于这次设计的是UserBean对RoleBean的单向联系,所以只需要在UserBean中添加方法标记即可。
切换到 UserBean.java ,右击 UserBean ->J2EE ->Add CMR Relationship :
 
 
· 生成的标记如下,还需要手工添加一些@JBoss标记:
· 保存,Generate EJB Classes  
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值