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,管理学生的基本信息(姓名和各课分数),其中学生的分数又是一个实体Bean。TacherBean是一个无状态的会话Bean,用来调用实体Bean。和前面的例子一样,我们还是使用Client测试。
Student.java:实体Bean。
Score.java:实体Bean。
Teacher.java:会话Bean的业务接口
TeacherBean.java:会话Bean的实现类
Client.java:测试EJB的客户端类。
jndi.properties:jndi属性文件,提供访问jdni的基本配置属性。
Build.xml:ant 配置文件,用以编译、发布、测试、清除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 |