当前位置: 首页 > 图文教程 > 网络编程 > JSP > EJB3.0之实体Bean的继承

JSP
搭建Eclipse+MyEclipse开发环境
卖jsp编程技巧的那个垃圾的所有实例的答案全部已收集,现将他人收集的实例答案公布出来,大家鉴赏!
一个jsp+AJAX评论系统
JSP 多个文件打包下载代码
JSP 动态树的实现
jsp 重复提交问题
J2ME/J2EE实现用户登录交互 实现代码
访问JSP文件或者Servlet文件时提示下载的解决方法
JSP EL表达式详细介绍
JSP 报表打印的一种简单解决方案
jsp 自定义标签实例
AJAX自学练习 无刷新从数据库后台取数据显示
AJAX 自学练习 请求与显示
AJAX 自学练习 无刷新提交并修改数据库数据并显示
jsp 文件上传浏览,支持ie6,ie7,ie8
JSP application(return String)用法详例
jsp form表单方法示例
JSP request(return String)用法详例
JSP forward用法分析实例代码分析
JSP JavaBean的setProperty属性

JSP 中的 EJB3.0之实体Bean的继承


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 61 ::
收藏到网摘: n/a

在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 –c all,启动JBOSS。
  http://localhost:8080/jmx-console/HtmlAdaptor?action=inspectMBean&name=jboss%3Aservice%3DHypersonic%2Cdatabase%3DlocalDB,然后调用startDatabaseManager()方法,打开HSQL管理工具管理数据库。
  在Eclipse的Ant视图中执行ejbjar target。或者在命令行下,进入到此工程目录下,执行ant ejbjar,将编译打包发布此EJB。
  在Eclipse的Ant视图中执行run target。或者在命令行下,进入到此工程目录下,执行ant run,测试这个EJB。