EJB3.0之实体Bean的继承

EJB

  在EJB3.0中,实体Bean可以实现继承关系。 比如有个Person的实体bean,它有姓名和性别两个属性。

  上帝和女娲造人的时候,造出两种人:Man和Woman。Man和Woman都是实体Bean,而且他们都继承Person。

  单一表策略就是副实体和子实体的数据都存放在一张表中,同时指定一列用来区别这些实体。

  如:

  @Entity
  @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = DiscriminatorType.STRING)
  @DiscriminatorColumn(name = "P_TYPE", nullable = true)
  @ Inheritance的注释声明如下:
  @ @Target({TYPE}) @Retention(RUNTIME)

  public @interface Inheritance {
  InheritanceType strategy() default SINGLE_TABLE;
  DiscriminatorType discriminatorType() default STRING;
  String discriminatorValue() default "";
  }

  这个注释用来指定继承使用的策略,以及为了区别这些实体所用的列的类型与值。

  @DiscriminatorColumn注释用在单一表策略和联合表策略上。用来指定区别各实体所需的列。
  @Target({TYPE}) @Retention(RUNTIME)

  public @interface DiscriminatorColumn {
  String name() default "";
  boolean nullable() default false;
  String columnDefinition() default "";
  int length() default 10;
  }

  这个例子主要有以下几个文件,这个例子主要实现了Person和Man、Woman之间的继承关系,下面两章介绍的例子和这个例子相同。Man和Woman继承Person实体Bean。前面的例子一样,我们还是使用Client测试。

  Person.java:实体Bean。

  Man.java:实体Bean所依赖的类。

  Woman.java:实体Bean所依赖的类。

  PersonTest.java:会话Bean的业务接口

  PersonTestBean.java:会话Bean的实现类

  Client.java:测试EJB的客户端类。

  jndi.properties:jndi属性文件,提供访问jdni的基本配置属性。

  Build.xml:ant 配置文件,用以编译、发布、测试、清除EJB。

  下面针对每个文件的内容做一个介绍。

  Person.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.ejb.DiscriminatorColumn;
  import javax.ejb.DiscriminatorType;
  import javax.ejb.Entity;
  import javax.ejb.GeneratorType;
  import javax.ejb.Id;
  import javax.ejb.Inheritance;
  import javax.ejb.InheritanceType;

  @Entity
  @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = DiscriminatorType.STRING)
  @DiscriminatorColumn(name = "P_TYPE", nullable = true)
  public class Person implements java.io.Serializable
  {
  private int id;
  private String name;
  private String gender;

  @Id(generate = GeneratorType.AUTO)

  public int getId()
  {
  return id;
  }

  public void setId(int id)
  {
  this.id = id;
  }

  public String getName()
  {
  return name;
  }

  public void setName(String name)
  {
  this.name = name;
  }

  public void setGender(String gender)
  {
  this.gender = gender;
  }

  public String getGender()
  {
  return gender;
  }

  }

  指定使用P_TYPE列用来区别各实体Bean。

  Man.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.ejb.DiscriminatorType;
  import javax.ejb.Entity;
  import javax.ejb.Inheritance;
  import javax.ejb.InheritanceType;

  @Entity
  @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = DiscriminatorType.STRING, discriminatorValue = "Man")

  public class Man extends Person
  {
  private boolean isGood;
  public void setGood(boolean isGood)
  {
  this.isGood = isGood;
  }

  public boolean isGood()
  {
  return isGood;
  }
  }

  这个实体Bean增加了一个是否是好男人的属性。

  Woman.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.ejb.DiscriminatorType;
  import javax.ejb.Entity;
  import javax.ejb.Inheritance;
  import javax.ejb.InheritanceType;

  @Entity
  @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = DiscriminatorType.STRING, discriminatorValue = "Woman")

  public class Woman extends Person
  {
  private boolean isbeautiful;

  public void setIsbeautiful(boolean isbeautiful)
  {
  this.isbeautiful = isbeautiful;
  }

  public boolean isIsbeautiful()
  {
  return isbeautiful;
  }

  }

  EntityTest.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.ejb.Remote;
  import java.util.List;

  @Remote

  public interface PersonDAO
  {
  public int createMan(String name,String gender,boolean b);
  public int createWoman(String name,String gender,boolean b);
  public Person find(int i);
  public List findByName(String name);
  public List findByInfo(String gender);
  }

  PersonTestBean.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.ejb.EntityManager;
  import javax.ejb.Inject;
  import javax.ejb.Stateless;
  import java.util.List;

  @Stateless

  public class PersonDAOBean implements PersonDAO
  {
  @Inject
  private EntityManager manager;

  public int createMan(String name,String gender,boolean b)
  {
  Man man = new Man();
  man.setName(name);
  man.setGender(gender);
  man.setGood(b);
  manager.create(man);
  return man.getId();
  }

  public int createWoman(String name, String gender,boolean b)
  {
  Woman woman = new Woman();
  woman.setName(name);
  woman.setGender(gender);
  woman.setIsbeautiful(b);
  manager.create(woman);
  return woman.getId();
  }

  public Person find(int i)
  {
  return manager.find(Person.class,i);
  }

  public List findByName(String name)
  {
  return manager.createQuery("from Person p where p.name =:name").setParameter("name", name).listResults();
  }

  public List findByInfo(String gender)
  {
  return manager.createQuery("from Person p where p.gender =:gender").setParameter("gender", gender).listResults();
  }

  }

  在这个会话Bean中提供了创建Man、Woman实体Bean的方法,并提供了查找方法。

  Client.java

  package com.kuaff.ejb3.singleinheritance;

  import javax.naming.InitialContext;
  import javax.naming.NamingException;
  import java.util.List;

  public class Client
  {
  public static void main(String[] args) throws NamingException
  {
  InitialContext ctx = new InitialContext();
  PersonDAO dao = (PersonDAO) ctx.lookup(PersonDAO.class.getName());
  int i = dao.createMan("晁岳攀","男",true);
  dao.createWoman("朱立焕","女",true);
  Person p = dao.find(i);
  System.out.printf("%s的性别:%s%n",p.getName(),p.getGender());
  List list = dao.findByName("朱立焕");

  for (Object o:list)
  {
   Woman w = (Woman)o;
   System.out.printf("%s漂亮吗?结论:%b%n",w.getName(),w.isIsbeautiful());
  }
  }

  }

  这个客户端用来测试。

  请运行{$JBOSS_HOME}/bin目录下的run.bat: run

时间: 2024-10-25 17:54:30

EJB3.0之实体Bean的继承的相关文章

EJB3.0之实体Bean的继承_JSP编程

在EJB3.0中,实体Bean可以实现继承关系. 比如有个Person的实体bean,它有姓名和性别两个属性. 上帝和女娲造人的时候,造出两种人:Man和Woman.Man和Woman都是实体Bean,而且他们都继承Person. 单一表策略就是副实体和子实体的数据都存放在一张表中,同时指定一列用来区别这些实体. 如: @Entity @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = Discrim

一步一步学EJB3.0(四):实体Bean开发

EJB3.0实体Bean开发是是很简单的,主要就是学习标注的使用, 现在EJB3实体Bean是纯粹的POJO.实际 上这表达了和Hibernate持久化实体对象同样的概念.它们的映射都通过JDK5.0注解来定义(EJB3规范已经 定义了对应的XML描述语法).注解分为两个部分,分别是逻辑映射注解和物理映射注解,通过逻辑映射注解 可以描述对象模型,类之间的关系等等,而物理映射注解则描述了物理的schema,表,列,索引等等. 这些标注都封装在javax.persistence包下,如果是使用Hib

EJB 3.0开发指南之实体Bean的继承

在EJB3.0中,实体Bean可以实现继承关系. 比如有个Person的实体bean,它有姓名和性别两个属性. 上帝和女娲造人的时候,造出两种人:Man和Woman.Man和Woman都是实体Bean,而且他们都继承Person. 单一表策略就是副实体和子实体的数据都存放在一张表中,同时指定一列用来区别这些实体. 如: @Entity @Inheritance(strategy = InheritanceType.SINGLE_TABLE, discriminatorType = Discrim

eclipse + JBoss 5 + EJB3开发指南(10):通过继承实体Bean,将单个表映射成多个表(单表策略,SINGLE_TABLE)

本文为原创,如需转载,请注明作者和出处,谢谢! 上一篇:eclipse + JBoss 5 + EJB3开发指南(9):实现Entity Bean的多对多(many-to-many)映射     如果以前使用过EJB1.x或EJB2.x的实体Bean,会发现无法通过继承实体Bean将单个表分成多表.而在EJB3中,我们很容易实现这个功能.先看看图1所示的表结构和记录. 图1   t_accounts表的结构和记录 在t_accounts表中,有一个account_type字段.这个字段是一个长度

EJB3.0新规范概览及其未来发展

规范 引言 期待已久的EJB3.0规范在最近发布了它的初稿.在本文中将对新的规范进行一个概要性的介绍,包括新增的元数据支持,EJBQL的修改,实体Bean模型访问bean上下文的新方法和运行时环境等等.作者还讨论了EJB在未来要作出的调整以及EJB3.0与其他开发规范之间的关系. 开始 无论如何由于EJB的复杂性使之在J2EE架构中的表现一直不是很好.EJB大概是J2EE架构中唯一一个没有兑现其能够简单开发并提高生产力的组建. EJB3.0规范正尝试在这方面作出努力以减轻其开发的复杂性.EJB3

session-EJB3.0中Session Bean的组成可以包括

问题描述 EJB3.0中Session Bean的组成可以包括 解决方案 这道题选择acde 解决方案二: EJB3.0---Stateless session bean

eclipse + JBoss 5 + EJB3开发指南(6):编写第一个实体Bean程序

EJB3容器通过EntityManager对象管理实体Bean,该类最主要的功能就是在记录和JavaBean之间进行互 相映射.例如,我们从数据库中查出一条记录,这条记录有field1和field2两个字段,假设有一个 JavaBean,也包含了field1和field2属性.那么EntityManager可以将这条记录中的值映射到JavaBean的 field1和field2属性中.也就是说,在数据库中的一条记录就对应于一个JavaBean的对象实例.下面将给 出一个简单的例子来演示如何来实现

EJB 3.0开发指南之实体Bean

在EJB3.0中开发实体Bean非常简单,你可以象开发一般的java bean一样编程,只需做少量的注释.一个实体bean不需要实现Home接口或者Remote.Local接口. 实体Bean通过EntityManager产生.查找.和持久层结合.从持久层收回等操作. JBoss的EJB3.0架构在Hibernate之上. 注释: @Entity:如果你要建立一个实体Bean的类,你必须在类上加上这个注释,用来告诉容器这个类是实体Bean.这个Bean的主键由@Id指定. 这个注释的声明如下:

eclipse + JBoss 5 + EJB3开发指南(11):实体Bean的连接策略(JOINED Strategy)

本文为原创,如需转载,请注明作者和出处,谢谢! 上一篇:eclipse + JBoss 5 + EJB3开发指南(10):通过继承实体Bean,将单个表映射成多个表(单表策略,SINGLE_TABLE)    在上一篇文章中,使用单表策略将一个表从逻辑上分成了多个表.但这样可能会造成空巢字段,也就是说,一个逻辑表只由部分字段组成,而物理的表的很多字段的值就会为null.为了解决这个问题,可以将t_accounts表物理地分成多个表.为了与t_accounts表进行对比,新建一个t_myaccou