象的时候,无须使用像JDBC 那样繁琐的API。在EJB 的早期版本中,持久化是EJB 平台的一部分。从EJB 3.0
开始,持久化已经自成规范,被称为Java Persistence API。
通Java 对象被称作entity bean。除了是用Java Persistence 元数据将其映射到数据库外,entity bean 与其他Java 类
没有任何区别。事实上,创建一个Entity Bean 对象相当于新建一条记录,删除一个Entity Bean 会同时从数据库
中删除对应记录,修改一个Entity Bean 时,容器会自动将Entity Bean 的状态和数据库同步。
一个实体Bean 应用由实体类和persistence.xml 文件组成。persistence.xml 文件在Jar 文件的META-INF 目录。
persistence.xml 文件指定实体Bean 使用的数据源及EntityManager 对象的默认行为。persistence.xml 文件的配置说
明如下:
<?xml version="1.0"?> <persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0"> <persistence-unit name="foshanshop"> <!--名称和注入em时指定的persistenceContext注释的unitName属性相同--> <jta-data-source>java:/DefaultMySqlDS</jta-data-source> <!--名称和数据源oracle-ds文件中jndi-name属性相同--> <properties> <property name="hibernate.hbm2ddl.auto" value="create-drop"/> <!-- 调整JDBC抓取数量的大小: Statement.setFetchSize() --> <property name="hibernate.jdbc.fetch_size" value="18"/> <!-- 调整JDBC批量更新数量 --> <property name="hibernate.jdbc.batch_size" value="10"/> <!-- 显示最终执行的SQL --> <property name="hibernate.show_sql" value="true"/> <!-- 格式化显示的SQL --> <property name="hibernate.format_sql" value="true"/> </properties> </persistence-unit> </persistence>
如果persistence.xml 文件中配置了多个不同的持久化内容。在注入EntityManager 对象时必须指定持久化名称,可
以通过@PersistenceContext 注释的unitName 属性进行指定,例:
EntityManager em;
如果只有一个持久化内容配置,不需要明确指定。
小提示:如果你的表已经存在,并且想保留数据,发布实体bean 时可以把hibernate.hbm2ddl.auto 的值设为none 或
update,以后为了实体bean 的改动能反应到数据表,建议使用update,这样实体Bean 添加一个属性时能同时在数
据表增加相应字段。