文档章节

EJB---->实体Bean(Entity Bean) 持久化 和 persistence.xml 配置文件

小强斋太
 小强斋太
发布于 2016/11/09 20:07
字数 970
阅读 19
收藏 0
持久化是位于JDBC 之上的一个更高层抽象。持久层将对象映射到数据库,以便在查询、装载、更新,或删除对
象的时候,无须使用像JDBC 那样繁琐的API。在EJB 的早期版本中,持久化是EJB 平台的一部分。
从EJB 3.0
开始,持久化已经自成规范,被称为Java Persistence API。
Java Persistence API 定义了一种方法,可以将常规的普通Java 对象(有时被称作POJO)映射到数据库。这些普
通Java 对象被称作entity bean。除了是用Java Persistence 元数据将其映射到数据库外,entity bean 与其他Java 类
没有任何区别。事实上,创建一个Entity Bean 对象相当于新建一条记录,删除一个Entity Bean 会同时从数据库
中删除对应记录,修改一个Entity Bean 时,容器会自动将Entity Bean 的状态和数据库同步。
Java Persistence API 还定义了一种查询语言(JPQL),具有与SQL 相类似的特征,只不过做了裁减,以便处理Java对象而非原始的关系schema。
 
持久化persistence.xml 配置文件
一个实体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>
容器在实例化SessionBean 后,就通过@PersistenceContext 注释动态注入EntityManager 对象。
如果persistence.xml 文件中配置了多个不同的持久化内容。在注入EntityManager 对象时必须指定持久化名称,可
以通过@PersistenceContext 注释的unitName 属性进行指定,例:
@PersistenceContext(unitName="foshanshop")
EntityManager em;
如果只有一个持久化内容配置,不需要明确指定。
 
persistence-unit 节点可以有一个或多个,每个persistence-unit 节点定义了持久化内容名称、使用的数据源及持久化产品专有属性。name 属性定义持久化名称。jta-data-source 节点指定实体Bean 使用的数据源JNDI 名称(如何配置数据源请参考下节“Jboss 数据源的配置”),如果应用发布在jboss 下数据源名称必须带有java:/前缀,数据源名称大小写敏感。properties 节点用作指定持久化产品的各项属性,各个应用服务器使用的持久化产品都不一样如Jboss 使用Hibernate。因为jboss 采用Hibernate,Hibernate 有一项属性hibernate.hbm2ddl.auto,该属性指定实体Bean 发布时是否同步数据库结构,如果hibernate.hbm2ddl.auto 的值设为create-drop,在实体Bean 发布及卸载时将自动创建及删除相应数据库表(注意:Jboss 服务器启动或关闭时也会引发实体Bean 的发布及卸载)。
关于hibernate 的可用属性及默认值你可以在[Jboss 安装目录]\server\default\deploy\ejb3.deployer\META-INF/persistence.properties 文件中看见.
小提示:如果你的表已经存在,并且想保留数据,发布实体bean 时可以把hibernate.hbm2ddl.auto 的值设为none 或
update,以后为了实体bean 的改动能反应到数据表,建议使用update,这样实体Bean 添加一个属性时能同时在数
据表增加相应字段。


 

本文转载自:http://www.cnblogs.com/xqzt/archive/2012/05/15/5637388.html

共有 人打赏支持
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
私信 提问
spring mvc 整合 jpa 搭建基于领域驱动模型框架搭建

一、maven pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 h......

漂泊者及其影子
2014/06/16
0
0
jdbc-jdbcTemplate-hibernate-jpa-springDataJpa系列(二)

1 前面的文章索引 - jdbc开发和事务的使用- spring-jdbcTemplate开发和事务的使用- hibernate的原生xml方式开发和事务的使用- hibernate的原生xml方式与spring集成以及事务的使用- hibernate...

乒乓狂魔
2015/04/23
0
5
一个简单的项目(click+spring+eclipselink jpa)

一、框架介绍 1.Apache Click 是一个先进的Java企业版的Web应用程序框架,提供一个基于浏览器的富客户端编程模型。 主要的特点包括: 易学 面向组件和页面的设计 基于事件的编程模型 性能非常...

南的糊途
2013/03/15
0
0
Spring集成JPA后,报“Not an managed type: class x.x.x"

以前的Spring脚手架项目,因业务需要,是基于多数据源 and不同方言的数据库的,对于普通项目过于复杂了, 于是重新搭了个单数据源的,用STS新建完毕,这是项目目录, 加上配置之后,先列下a...

Big_BoBo
2015/08/01
0
1
(翻译)Spring到Java EE的迁移

原文http://www.oracle.com/technetwork/articles/java/springtojavaee-522240.html By David Heffelfinger CTO and ardent Java EE fan David Heffelfinger demonstrates how easy it is to......

davelet
2011/12/30
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CAS和AQS

CAS(Compare And Swap) 什么是CAS CAS(Compare And Swap),即比较并交换。是解决多线程并行情况下使用锁造成性能损耗的一种机制。 CAS是一种系统原语,原语属于操作系统用语范畴,是由若干条...

狼王黄师傅
13分钟前
1
0
Python利用pandas处理Excel数据的应用

Python利用pandas处理Excel数据的应用 最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化...

上官夏洛特
27分钟前
1
0
100:代码管理平台svn

1:代码管理平台:代码版本管理工具,工作中用于代码更新,代码发布统计,代码版本控制;(频繁更新代码的版本记录),方便查阅历史变更,协同开发及合并; 版本管理工具发展: cvs(编码兼容不太好)...

芬野de博客
27分钟前
0
0
Linux学习-1101(rsync下、log、screen)

10.32/10.33 rsync通过服务同步 10.34 linux系统日志 10.35 screen工具 一、 rsync通过服务同步 rsync 通过服务的方式同步,首先需要开启一个服务。它是C/S架构,开启rsync服务,默认端口是8...

wxy丶
34分钟前
1
0
使用jpmml-sparkml-executable生成PMML模型文件

加载依赖的jar包通过./spark-shell --jars ./jpmml-sparkml-executable-1.2.13.jar 启动spark import org.apache.spark.ml.classification.LogisticRegressionimport org.apache.spark.m......

KYO4321
37分钟前
1
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部