在上面一个例子中,实体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);
}