一个实体Bean可以映射到多张表上。在一些需要字典表的项目上会经常用到,象以前我做过的项目,使用到很多国标规定的数据表。在我们下面这个例子中,性别作为一个字典表存在,学生这个实体将映射到学生信息表、性别表这两个表。
从表可以使用@SecondaryTable来注释:
@Target({TYPE}) @Retention(RUNTIME)
public @interface SecondaryTable {
String name();
String catalog() default "";
String schema() default "";
JoinColumn[] join() default {};
UniqueConstraint[] uniqueConstraints() default {};
}
这个注释可以指定表名、分类、schema、联合列、约束等。假如你使用多张表,你可以使用下面的注释来声明多张表:
@SecondaryTable
@Target({TYPE}) @Retention(RUNTIME)
public @interface SecondaryTables {
SecondaryTable[] value() default {};
}
这个例子主要有以下几个文件,这个例子主要实现了管理学生的功能。Student是一个实体Bean,这个Bean的name属性是一个类,也就是Name类,这个Name类就是一个依赖值对象。学生的性别映射到第二张表中。StudentDAOBean是一个无状态的会话Bean,用来调用实体Bean。和前面的例子一样,我们还是使用Client测试。
这个例子和上一个例子基本相同,只是Student.java和Client有所不同。
Student.java:实体Bean。
Name.java:实体Bean所依赖的类。
StudentDAO.java:会话Bean的业务接口
StudentDAOBean.java:会话Bean的实现类
Client.java:测试EJB的客户端类。
jndi.properties:jndi属性文件,提供访问jdni的基本配置属性。
Build.xml:ant 配置文件,用以编译、发布、测试、清除EJB。
下面针对每个文件的内容做一个介绍。
Student.java
package com.kuaff.ejb3.secondary;
import javax.ejb.Dependent;
import javax.ejb.DependentAttribute;
import javax.ejb.Column;
import javax.ejb.Entity;
import javax.ejb.GeneratorType;
import javax.ejb.Id;
import javax.ejb.Table;
import javax.ejb.SecondaryTables;
import javax.ejb.SecondaryTable;
import javax.ejb.JoinColumn;
@Entity
@Table(name = "STUDENT")
@SecondaryTables({
@SecondaryTable(name = "GENDER", join = {@JoinColumn(name = "GENDER_ID")})
})
public class Student implements java.io.Serializable
{
private int id;
private Name name;
private String grade;
private String email;
private String gender;
@Id(generate = GeneratorType.AUTO)
public int getId()
{
return id;
}
public void setId(int id)
{
this.id = id;
}
public void setName(Name name)
{
this.name = name;
}
@Dependent({ @DependentAttribute(name = "first", column ={ @Column(name = "FIRST") }),
@DependentAttribute(name = "last", column ={ @Column(name = "LAST") }) })
public Name getName()
{
return name;
}
public void setGrade(String grade)
{
this.grade = grade;
}
@Column(name = "GRADE")
public String getGrade()
{
return grade;
}
public void setEmail(String email)
{
this.email = email;
}
@Column(name = "EMAIL")
public String getEmail()
{
return email;
}
public void setGender(String gender)
{
this.gender = gender;
}
@Column(name = "gender", secondaryTable = "GENDER")
public String getGender()
{
return gender;
}
}
Student.java实现了Student实体Bean,它提供学生的基本情况。在类上声明上加上了第二张表的注释:
@SecondaryTables({
@SecondaryTable(name = "GENDER", join = {@JoinColumn(name = "GENDER_ID")})
})
在gender属性上加上了映射第二张的注释:
@Column(name = "gender", secondaryTable = "GENDER")
Client.java
package com.kuaff.ejb3.secondary;
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();
StudentDAO dao = (StudentDAO) ctx.lookup(StudentDAO.class.getName());
int id = dao.create("晁","岳攀","8","smallnest@kuaff.com","男");
dao.create("朱","立焕","6","zhuzhu@kuaff.com","女");
List list = dao.findAll();
for(Object o:list)
{
Student s = (Student)o;
System.out.printf("%s%s的性别:%s%n",s.getName().getFirst(),s.getName().getLast(),s.getGender());
dao.evict(s);
}
这个客户端增加学生的分数,并且测试显示这个学生的email。
请运行{$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。
分享到:
相关推荐
在EJB 3.0开发中,多表映射是一个重要的概念,特别是在处理复杂数据模型时。本教程聚焦于如何使用Java和EJB 3.0标准来映射实体Bean到多个数据库表。EJB(Enterprise JavaBeans)是Java EE平台的一部分,用于构建企业...
这种模式允许实体Bean的属性引用其他Java对象,而这些对象并不直接与数据库中的表进行映射。本教程将详细介绍如何在EJB 3.0中使用依赖值对象,并通过一个具体的示例来说明其应用。 1. **依赖值对象的概念** - 依赖...
总之,《EJB 3.0从入门到精通》教程是一本全面覆盖EJB 3.0及其相关技术的指南,适合初学者和有一定经验的开发者。通过深入学习和实践,读者将能够熟练地运用EJB 3.0开发高效、可靠的Java EE应用。
《精通EJB 3.0》是一本专为Java企业级开发者编写的指南,它深入讲解了Enterprise JavaBeans(EJB)3.0版本的核心概念和技术。EJB是Java平台上用于构建可扩展、安全和事务处理的企业级应用程序的重要组件模型。这本书...
3. **ejb3.0-1.pdf** - 这可能是EJB 3.0的特定部分或专题教程,比如可能专门讲解新的JPA(Java Persistence API)或者EJB 3.0的容器服务,如依赖注入、声明式事务管理等。 4. **EJB3.rar** - 这个RAR文件可能包含源...
**ejb3.0中英文规范** Enterprise JavaBeans (EJB) 3.0是Java平台上企业级应用程序开发的重要组成部分,它提供了服务器端组件模型,用于构建可扩展、安全且可移植的分布式业务应用程序。EJB 3.0规范旨在简化开发...
EJB(Enterprise JavaBeans)是Java企业级应用开发的核心组件之一,主要负责处理服务器端的业务逻辑。EJB 3.0是EJB规范的一个重要版本,它在EJB 2.x的基础上进行了重大改进,降低了开发复杂性,提高了开发者效率。本...
本指南结合了EJB3.0的最新规范,以及JBoss应用程序服务器的实践经验,旨在帮助读者掌握EJB3.0开发的精髓。 EJB3.0标准带来了许多显著的改进,其中最重要的是简化了API,降低了开发复杂性。它引入了注解...
若想获取更多实践示例,可以参考JBoss EJB 3.0指南或直接查看Hibernate Annotations的测试代码,这些测试用例通常包含实际应用的例子。 一个持久化POJO类通过`@Entity`注解声明为实体Bean,如下所示: ```java @...
本书不仅是一份详尽的技术指南,更是EJB 3.0实践者的宝典,它覆盖了从基础到高级的所有知识点,适合于初学者和有经验的开发者。通过阅读本书,读者将能够全面掌握EJB 3.0的核心技术和最佳实践,从而在企业级Java开发...
此外,书中还讲解了实体Bean的发布前准备、单表映射、持久化实体管理器ENTITYMANAGER的使用方法,以及关系/对象映射的细节,如一对多、多对一、一对一和多对多的关系映射,这些内容都是实体Bean开发中的核心技能。...
《最新EJB3.0教程》是一份详尽的指南,专为希望深入了解Java企业级应用程序接口(EJB)3.0版本的开发者设计。EJB3.0是Java平台企业版(J2EE)的一部分,旨在简化企业级Java应用程序的开发过程,通过提供组件模型来支持...
《精通EJB 3.0第四版》是针对企业级JavaBeans(Enterprise JavaBeans,简称EJB)技术的一本深入指南,特别关注EJB 3.0版本的特性与实践。EJB是Java平台企业版(Java EE)的核心组件之一,用于构建可扩展、安全且事务...
根据提供的文件信息,我们可以推断出这是一本关于EJB 3.0的书籍,书名为《Manning EJB3.0 in action》。虽然标题和描述中的故事似乎与EJB 3.0无关,但从部分内容来看,这本书显然是专注于EJB 3.0的技术细节及其在...
**EJB 3.0 学习指南** EJB(Enterprise JavaBeans)是Java平台企业版(Java EE)的一部分,用于构建可扩展、安全且事务处理能力强大的分布式应用程序。EJB 3.0是该技术的一个重要里程碑,它极大地简化了开发过程,...
《Pro EJB 3.0》是针对企业级JavaBeans(EJB)3.0版本的一本专业指南,英文版提供了全面深入的EJB技术详解。这本书主要关注于EJB 3.0 Java Persistence API(JPA),这是Java平台中用于持久化数据的重要组件。EJB ...