EJB3.0之如何使用实体Bean?

EJB3.0之如何使用实体Bean?

在上面一个例子中,实体Bean的属性对应到数据表中的列,都是采用默认的设置。通过Column,你可以为属性指定数据表中的列名。

Column的声明如下:

@Target({TYPE, METHOD, FIELD}) @Retention(RUNTIME)

public @interface Column {

String name() default "";

boolean primaryKey() default false;

boolean unique() default false;

boolean nullable() default true;

boolean insertable() default true;

boolean updatable() default true;

String columnDefinition() default "";

String secondaryTable() default "";

int length() default 255;

int precision() default 0;

int scale() default 0;

boolean specified() default true; // For internal use only

}

 

EntityManager 是用来处理实体Bean的辅助类。它可以用来产生/删除持久化的实体Bean,通过主键查找实体bean,通过查询语言来查询实体Bean

下面是EntityManager接口的声明:

package javax.ejb;

import java.sql.Connection;

/**

* 用来和持久化上下文交互的接口

*/

public interface EntityManager {

/**

* 使实体bean受持久化管理

* @param entity

*/

public void create(Object entity);

/**

* 将给定的实体Bean的状态和持久化上下文结合。类似数据库的更新操作。

* @param entity

* @return 被结合的实体实例

*/

public <T> T merge(T entity);

/**

* 删除实例

* @param entity

*/

public void remove(Object entity);

/**

* 根据主键查找.

* @param entityName

* @param primaryKey

* @return 查询实例

*/

public Object find(String entityName, Object primaryKey);

/**

* 根据主键查找

* @param primaryKey

* @return 查询实例

*/

public <T> T find(Class<T> entityClass, Object primaryKey);

/**

* 持久化上下文与底层数据库的同步

*/

public void flush();

/**

* 执行一个EJBQL查询

* @param ejbqlString EJBQL查询语句

* @return the new query instance

*/

public Query createQuery(String ejbqlString);

/**

* 执行命名的查询

* @param name 预定义的查询名称

* @return 查询实例

*/

public Query createNamedQuery(String name);

/**

* 执行一个本地SQL查询语句

* @param sqlString 本地查询语句

* @return 返回查询实例

*/

public Query createNativeQuery(String sqlString);

/**

* 更新到数据库中

* @param entity

*/

public void refresh(Object entity);

/**

* 持久化上下文中删除实体

* @param entity

*/

public void evict(Object entity);

/**

* 检查当前上下文中是否包含此实体

* context.

* @param entity

* @return

*/

public boolean contains(Object entity);

}

 

@JoinColumns

用来指示符合主键,在后面的章节中介绍。
 

这个例子主要有以下几个文件,这个例子主要实现了管理学生分数的功能。Student是一个实体Bean,管理学生的基本信息(姓名和各课分数),其中学生的分数又是一个实体BeanTacherBean是一个无状态的会话Bean,用来调用实体Bean。和前面的例子一样,我们还是使用Client测试。

 

Student.java:实体Bean

Score.java:实体Bean

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

TeacherBean.java:会话Bean的实现类

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

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

Build.xmlant 配置文件,用以编译、发布、测试、清除EJB

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

 

Student.java

 

package com.kuaff.ejb3.entity;

 

import javax.ejb.CascadeType;

import javax.ejb.Entity;

import javax.ejb.FetchType;

import javax.ejb.GeneratorType;

import javax.ejb.Id;

import javax.ejb.JoinColumn;

import javax.ejb.OneToMany;

import javax.ejb.Table;

 

import java.util.ArrayList;

import java.util.Collection;

import java.io.Serializable;

 

@Entity

@Table(name = "STUDENT")

public class Student implements Serializable

{

//主键

private int id;

//学生名

private String name;

//学生的分数

private Collection<Score> scores;

//主键自动产生

@Id(generate = GeneratorType.AUTO)

public int getId()

{

return id;

}

 

public void setId(int id)<span style="FONT-SIZE: 10pt; FONT-FAMILY: 'Courier New'; ms