- 浏览: 701465 次
- 性别:
- 来自: 北京
博客专栏
-
读金庸故事,品程序人生
浏览量:47681
文章分类
最新评论
-
hty881008:
LZ,你的json返回是怎么出来的,我的怎么是No messa ...
使用CXF暴露您的REST服务 -
jxFY:
赞
Apache的对象池化工具commons-pool -
wangyudong:
新版本的Wisdom RESTClient地址https:// ...
使用CXF暴露您的REST服务 -
wangyudong:
由CXF实现的微服务需要有比较好的工具去测试RESTful A ...
使用CXF暴露您的REST服务 -
spring_springdata:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
Maven3实战笔记01环境配置与使用入门
1. 前言:
本文是学习JPA 笔记,可能会根据自己的学习进度逐渐完善。学习中使用的持久层技术
是EJB,JPA 注解方式,底层应用的是Hibernate 实现和MySql 数据库,应用服务器采
用的是JBoss 4.2.0。随着笔者的学习笔记,大家一起学习吧,还是那句话,有什么问题
大家一起探讨。有什么错误希望指证!谢谢。
2. 环境
先准备好数据库和JBoss 应用服务器,将JBoss 和MyEclipse 的应用服务器集成起来(不
好意思,笔者最喜欢用MyEclipse)集成步骤如下图:
好的,下面建立一个Web 项目吧,取名字就叫做JPAEJB,之后加入环境需要的jar 包,
jar 包的目录如下,CSDN 只能允许上传20mb 的附件,所以只能先列出jar 包的列表。
/JPAEJB/WEB-INF/lib/activation.jar
/JPAEJB/WEB-INF/lib/antlr.jar
/JPAEJB/WEB-INF/lib/avalon-framework.jar
/JPAEJB/WEB-INF/lib/commons-codec.jar
/JPAEJB/WEB-INF/lib/commons-httpclient.jar
/JPAEJB/WEB-INF/lib/commons-logging.jar
/JPAEJB/WEB-INF/lib/concurrent.jar
/JPAEJB/WEB-INF/lib/ejb3-persistence.jar
/JPAEJB/WEB-INF/lib/getopt.jar
/JPAEJB/WEB-INF/lib/hibernate-annotations.jar
/JPAEJB/WEB-INF/lib/hibernate-client.jar
/JPAEJB/WEB-INF/lib/jacorb.jar
/JPAEJB/WEB-INF/lib/javassist.jar
/JPAEJB/WEB-INF/lib/jaxb-api.jar
/JPAEJB/WEB-INF/lib/jaxb-impl.jar
/JPAEJB/WEB-INF/lib/jaxb-xjc.jar
/JPAEJB/WEB-INF/lib/jboss-annotations-ejb3.jar
/JPAEJB/WEB-INF/lib/jboss-aop-jdk50-client.jar
/JPAEJB/WEB-INF/lib/jboss-aspect-jdk50-client.jar
/JPAEJB/WEB-INF/lib/jboss-client.jar
/JPAEJB/WEB-INF/lib/jboss-common-client.jar
/JPAEJB/WEB-INF/lib/jboss-deployment.jar
/JPAEJB/WEB-INF/lib/jboss-ejb3-client.jar
/JPAEJB/WEB-INF/lib/jboss-ejb3x.jar
/JPAEJB/WEB-INF/lib/jboss-iiop-client.jar
/JPAEJB/WEB-INF/lib/jboss-j2ee.jar
/JPAEJB/WEB-INF/lib/jboss-jaxrpc.jar
/JPAEJB/WEB-INF/lib/jboss-jaxws.jar
/JPAEJB/WEB-INF/lib/jboss-jsr77-client.jar
/JPAEJB/WEB-INF/lib/jboss-remoting.jar
/JPAEJB/WEB-INF/lib/jboss-saaj.jar
/JPAEJB/WEB-INF/lib/jboss-serialization.jar
/JPAEJB/WEB-INF/lib/jboss-srp-client.jar
/JPAEJB/WEB-INF/lib/jboss-system-client.jar
/JPAEJB/WEB-INF/lib/jboss-transaction-client.jar
/JPAEJB/WEB-INF/lib/jboss-xml-binding.jar
/JPAEJB/WEB-INF/lib/jbossall-client.jar
/JPAEJB/WEB-INF/lib/jbosscx-client.jar
/JPAEJB/WEB-INF/lib/jbossha-client.jar
/JPAEJB/WEB-INF/lib/jbossjmx-ant.jar
/JPAEJB/WEB-INF/lib/jbossmq-client.jar
/JPAEJB/WEB-INF/lib/jbosssx-client.jar
/JPAEJB/WEB-INF/lib/jbossws-client.jar
/JPAEJB/WEB-INF/lib/jbossws-wsconsume-impl.jar
/JPAEJB/WEB-INF/lib/jmx-client.jar
/JPAEJB/WEB-INF/lib/jmx-invoker-adaptor-client.jar
/JPAEJB/WEB-INF/lib/jnp-client.jar
/JPAEJB/WEB-INF/lib/log4j-1.2.15.jar
/JPAEJB/WEB-INF/lib/logkit.jar
/JPAEJB/WEB-INF/lib/mail.jar
/JPAEJB/WEB-INF/lib/scout.jar
/JPAEJB/WEB-INF/lib/servlet-api.jar
/JPAEJB/WEB-INF/lib/stax-api.jar
/JPAEJB/WEB-INF/lib/trove.jar
/JPAEJB/WEB-INF/lib/wsdl4j.jar
/JPAEJB/WEB-INF/lib/wstx.jar
/JPAEJB/WEB-INF/lib/xmlsec.jar
/JPAEJB/WEB-INF/lib/antlr-2.7.6.jar
/JPAEJB/WEB-INF/lib/asm-attrs.jar
/JPAEJB/WEB-INF/lib/asm.jar
/JPAEJB/WEB-INF/lib/cglib-2.1.3.jar
/JPAEJB/WEB-INF/lib/commons-collections-2.1.1.jar
/JPAEJB/WEB-INF/lib/commons-logging-1.0.4.jar
/JPAEJB/WEB-INF/lib/dom4j-1.6.1.jar
/JPAEJB/WEB-INF/lib/ehcache-1.2.3.jar
/JPAEJB/WEB-INF/lib/hibernate-commons-annotations.jar
/JPAEJB/WEB-INF/lib/hibernate-entitymanager.jar
/JPAEJB/WEB-INF/lib/hibernate-validator.jar
/JPAEJB/WEB-INF/lib/hibernate3.jar
/JPAEJB/WEB-INF/lib/jaas.jar
/JPAEJB/WEB-INF/lib/jaxen-1.1-beta-7.jar
/JPAEJB/WEB-INF/lib/jboss-archive-browsing.jar
/JPAEJB/WEB-INF/lib/jdbc2_0-stdext.jar
/JPAEJB/WEB-INF/lib/jta.jar
/JPAEJB/WEB-INF/lib/junit.jar
/JPAEJB/WEB-INF/lib/xerces-2.6.2.jar
/JPAEJB/WEB-INF/lib/xml-apis.jar
/JPAEJB/WEB-INF/lib/mysql-connector-java-5.1.10-bin.jar
这些jar 包大多数在hiberntae、jboss、apache、mysql 等开源项目的lib 下面获取。有机
会笔者会将jar 发布到附件比较大的论坛上,抱歉~~~
现在,基本上一个简单的EJB-JPA 环境已经配置好了,下面我们开始JPA 的开发旅程吧。
3. 开发EJB 实体Bean
在src 下面建立eo 文件夹,之后建立一个类似于POJO 的对象,代码如下:
package eo;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name = "tb_customer")
public class CustomerEO implements Serializable {
/**
*
*/
private static final long serialVersionUID = -6746637486454652006L;
private Integer id;
private String name;
public CustomerEO(){
}
@Id
@Column(name = "id")
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
@Column(name = "name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
以上代码就是一个实体Bean,既然是实体Bean 就得实现Serializable,否则此Bean
不能被序列化,也就是说不能持久化在远端EJB 容器中。更别说通过消息队列反序列化成
对象了,所以必须实现此Serializable 接口。之后应该默认有一个无参数的构造函数(建
议:最好有,否则会调用父类的无参构造函数)。
下面就是解释JPA注解了,
@Entity注解,告诉编译器,此类不是一个普通的类,它是代表一个关系型数据库表的实体类
(注:JPA对面向对象的数据库支持的怎么样,笔者没有求证过,暂时不清楚!但是很不幸,笔
者在公司用过mongodb---一种对象型数据库,以JSON的形式存储记录。公司的做法是将所有
的JPA全部都剔除掉,由此可见JPA对非关系型数据库支持的还不是那么理想)。那么像这样类
的对象就可以被JPA自己的接口所识别,调用JPA的接口就可以达到JBDC操作关系表的作用了。
@Table(name = "tb_customer"),这个很简单,告诉JPA接口,这个类对应的是哪张表,
此时在关系型数据库中表明显而易见就是叫做“tb_customer”。如图,Mysql管理界面。
@Id,表示此属性在表的那边是主键,只要是实体Bean,必须有此主键注解,也就是说JPA的规
范:每张实体表必须得有主键,这个和我们自己Create表是不一样的,自己建表,可以存在没
有主键的情况,但是JPA规范就是如此,必须有主键!至于复合主键的情况,留给以后咱们学习。
@Column(name = "id")就是表明类中的属性对应关系表中的哪个字段,表结构如下图
此时我们将一个实体Bean写完了,那么按照业务需要,针对于这个实体Bean,应该编写DAO类。
我们暂时简单一些,就只先编一个保存方法,将记录保存到数据库中就算成了。
4. 开发DAO 业务Bean
下面在src下面建立dao包,先写一个接口:
package dao;
import javax.ejb.Remote;
import eo.CustomerEO;
@Remote
public interface ICustomerService {
public void save (CustomerEO customerEO);
}
可以看到此接口有一个@Remote注解,这是EJB自己的注解,代表此接口是在远程的服务器上部
署的,和真正调用的客户端耦合的只是接口。这个道理和Web Service是一样的。客户端需要
服务端提供服务,那么客户端只需要知道服务端提供的服务接口以及参数就可以了,具体服务实
现,那是服务端的事情,客户端不需要关心。在这里就是客户端需要远程的DAO接口提供增删改
查的服务,那么你服务端具体的增删改查业务实现和我客户端无关,客户端只需要知道你的接口
说明,传进参数,能调用成功就行。(如果读者稍微了解一些EJB2.X的知识,就知道这个@Remote
注解为开发者省去了多少复杂的配置)
下面在dao报下面建立一个impl包,创建一个类实现此接口,代码如下:
package dao.impl;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import dao.ICustomerService;
import eo.CustomerEO;
@Stateless
public class CustomerServiceImpl implements ICustomerService {
@PersistenceContext(unitName = "JPAEJBPU")
private EntityManager entityManager;
public void save(CustomerEO customerEO) {
entityManager.persist(customerEO);
}
}
@Stateless:代表是一个无状态的实现接口,这个回头逐渐地深入学习,再讨论……
7
@PersistenceContext(unitName = "JPAEJBPU"):代表使用JPA容器注入的方式将JPA
实体管理类注入到此DAO实现类中来,这个旧类似于Spring的依赖注入(IOC)。unitName =
"JPAEJBPU"中的JPAEJBPU是和JPA的配置文件中一致。至于EntityManager这个类,各位
读者,您就暂时先当成Hibernate的Session使用就成了。它封装了JPA自己的接口,使用这
些接口方法,即可完成增删改查操作。例如上面的persist方法就是持久化customerEO对象、
将相应的记录写入数据库、事务提交等等操作。
现在为止,代码就写到这里,还需要加入一个配置文件才能顺利使用JPA。在src下面建立
META-INF文件夹(包名的名字不能变),之后在此文件夹下面创建一个文件
persistence.xml,此配置文件内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<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="JPAEJBPU" transaction-type="JTA">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<jta-data-source>java:/jpaDemo</jta-data-source>
<properties>
<property name="hibernate.dialect"
value="org.hibernate.dialect.MySQLDialect" />
<property name="hibernate.format_sql" value="true" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.hbm2ddl.auto" value="update" />
</properties>
</persistence-unit>
</persistence>
一看便知,这个配置文件是用来配置数据源的信息的。
我的代码结构如下图:
5. 部署EJB 项目
下面用资源管理器打开你的JBoss 文件夹,我的JBoss 放在了,E:\server\jboss-4.2.0.GA
下面,打开E:\server\jboss-4.2.0.GA\server\default\deploy,在此文件夹下面建立一个文件
叫做mysql-ds.xml,内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!-- $Id: mysql-ds.xml 41016 2006-02-07 14:23:00Z acoliver $ -->
<!-- Datasource config for MySQL using 3.0.9 available from:
http://www.mysql.com/downloads/api-jdbc-stable.html
-->
<datasources>
<local-tx-datasource>
<jndi-name>jpaDemo</jndi-name>
<connection-url>jdbc:mysql://127.0.0.1:3306/ejbjpa?useUnicode=true&characterEncoding=
UTF-8</connection-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<user-name>root</user-name>
<password>root</password>
<exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</ex
ception-sorter-class-name>
<metadata>
<type-mapping>mySQL</type-mapping>
</metadata>
</local-tx-datasource>
</datasources>
这个文件的作用就是,应用服务器的数据源配置jndi-name 元素的值要和你自己的JPA
9
程序配置文件中的<jta-data-source> java:/xxxxxx 后面的名称要一致哦。
最后我们把自己的程序打成jar 包,放到E:\server\jboss-4.2.0.GA\server\default\deploy 下
面就可以了。这样我的E:\server\jboss-4.2.0.GA\server\default\deploy 文件夹如下:
可以看到,多了mysql-ds.xml 和JPAEJB.jar,2 个文件。
6. 测试
我们写一个测试程序来看看我们的程序是否正常运行吧。利用JUnit 测试,代码如下:
package client;
import java.util.Hashtable;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.rmi.PortableRemoteObject;
import junit.framework.TestCase;
import dao.ICustomerService;
import eo.CustomerEO;
public class TestJPAEJBDAO extends TestCase{
private static Context context;
public void test01() {
try {
Context ctx = getInitialContext();
Object object = ctx.lookup("CustomerServiceImpl/remote");
ICustomerService customerService = (ICustomerService)
PortableRemoteObject
.narrow(object, ICustomerService.class);
10
CustomerEO customerEO = new CustomerEO();
customerEO.setId(2);
customerEO.setName("素还真");
customerService.save(customerEO);
} catch (NamingException e) {
e.printStackTrace();
}
}
/**
* 得到JBoss应用服务器容器上下文
* @return
* @throws NamingException
*/
public static Context getInitialContext() throws NamingException {
if (context == null) {
Hashtable<String,String> pros = new
Hashtable<String,String>();
pros.put(Context.INITIAL_CONTEXT_FACTORY,
"org.jnp.interfaces.NamingContextFactory");
pros.put(Context.URL_PKG_PREFIXES,
"org.jboss.naming:org.jnp.interfaces");
pros.put(Context.PROVIDER_URL, "jnp://127.0.0.1:1099");
context = new InitialContext(pros);
}
return context;
}
}
启动一下JBoss 服务器,运行一下这个程序吧。运行后结果如下:
可以看到记录已经插进去了,到此我们对于JPA 简单的接口和EJB 部署已经有了了解,
以后继续学习,还会和大家分享,夜深了~~~~~2010-8-7 2:29。晚安………………
发表评论
-
JavaEE5实战笔记05RedHat搭建JBoss、Oracle10g环境
2011-06-01 10:50 1566JavaEE5实战笔记在RedHat上搭建JBoss、Orac ... -
JavaEE5实战笔记02JPA持久层的一些问题
2011-05-30 14:48 16001. JPA关联实体的级联操作问题 在此次联系中 ... -
JavaEE5实战笔记01EJB环境搭建及异常解决
2011-05-30 14:43 50131. 说明 此实战笔记是为了之前的学习笔记做一个 ... -
Spring集成ActiveMQ配置
2011-03-21 20:58 279451. 集成环境 Spring采用2.5.6版本, ... -
JAVA的Mina框架传递对象——一劳永逸(转载)
2011-03-09 11:31 2694接触java的Mina框架已经有很多时间了,在网上也读过了很多 ... -
JavaEE5学习笔记12-JSF验证器使用总结
2011-03-09 00:01 19661. JSF验证器 说完转换器就该说说验证器了, ... -
JavaEE5学习笔记11-JSF转换器使用总结
2011-03-08 23:53 27111. JSF的转换器是在JSF生命周期的第2个阶段 ... -
JSF组件生命周期的讨论
2011-03-08 23:38 17261. JSF生命周期 下面我们来看看JSF组件的 ... -
JavaEE5学习笔记10-JSF基本UI控件使用
2011-03-08 23:34 36621. JSF也是JavaEE5的标准,感觉上sun ... -
JavaEE5学习笔记09-将EJB发布成WebService总结(2)
2011-02-28 09:21 1546以上例子只是简单调用了WebService,参数是简单的Str ... -
JavaEE5学习笔记09-将EJB发布成WebService总结(1)
2011-02-28 09:19 41081. 将EJB发布成,或者说暴露成Web服务(也许 ... -
JavaEE5学习笔记08-JPA与EJB集成总结(4)
2011-02-24 09:36 14871. 在JavaEE容器 ... -
JavaEE5学习笔记08-JPA与EJB集成总结(3)
2011-02-24 09:35 11991. 测试代码 部署成功后,在另一个项目中建立测 ... -
JavaEE5学习笔记08-JPA与EJB集成总结(2)
2011-02-24 09:33 1523下面来看针对此实体操作的sessionBean代码。 接口 ... -
JavaEE5学习笔记08-JPA与EJB集成总结(1)
2011-02-24 09:28 1751JPA是JavaEE5提出的一套标准接口,不同的应用服务器对其 ... -
JavaEE5学习笔记06-EJB之消息驱动Bean(MDB)总结----2
2011-02-21 15:56 1423除了activationConfig之外,如果使用其他Java ... -
JavaEE5学习笔记06-EJB之消息驱动Bean(MDB)总结----1
2011-02-21 15:55 19601. 功能介绍 在EJB的分类中还有一个就是消息驱 ... -
JavaEE5学习笔记05-EJB之会话Bean(sessionBean)总结-----7
2011-02-21 09:49 13331. EJB的容器式依 ... -
JavaEE5学习笔记05-EJB之会话Bean(sessionBean)总结-----6
2011-02-21 09:48 1539BMT就是Bean自己管理事务,这种方式就是以硬编码的方式在B ... -
JavaEE5学习笔记05-EJB之会话Bean(sessionBean)总结-----5
2011-02-21 09:46 18971. 有状态的会话Bean的本地、远程调用 其实这 ...
相关推荐
在EJB(Enterprise JavaBeans)框架中,JPA被广泛使用,提供了一种面向对象的方式来处理数据库交互。本篇笔记主要聚焦于JPA的关联映射,这是JPA中一个重要的概念,用于定义实体之间的关系。 关联映射允许我们将...
### JPA学习笔记-EJB-02JPA属性注解 #### 一、引言 在上一篇文章中,我们简要介绍了Java Persistence API (JPA)的基础知识,包括它的基本部署和操作流程,从而让我们对JPA有了初步的认识。本文将继续深入探讨JPA的...
### JPA主键生成策略详解 #### 一、概述 持久化对象的主键生成机制在JPA(Java Persistence API)中占据着重要的位置。它不仅关乎数据的唯一标识符如何确定,还与数据的存储效率及应用逻辑紧密相关。JPA通过`@...
### JPA实体对象状态 #### 一、实体对象的状态分类 在Java Persistence API (JPA) 中,实体对象的状态管理是实现数据持久化的基础之一。根据实体对象与实体管理器(EntityManager)之间的交互关系,实体对象可以...
### JPA 学习笔记详解 #### 一、JPA 概述 Java Persistence API (JPA) 是 Sun 公司提出的一种 Java 持久层标准,它为 Java 开发者提供了一种对象关系映射 (ORM) 的工具来管理 Java 应用程序中的关系型数据。JPA ...
### Spring 使用 JPA 的知识点详解 #### 一、Spring与JPA简介 Spring框架与Java Persistence API (JPA)的结合...通过这些知识点的学习,可以更好地理解和掌握Spring JPA的使用方法,为后续的实际开发打下坚实的基础。
在深入探讨《ejb学习笔记》这一主题之前,我们首先需要理解什么是EJB(Enterprise JavaBeans)。EJB是Java平台为企业级应用开发提供的一套组件模型,它属于J2EE(Java 2 Platform, Enterprise Edition)的一部分,...
### EJB学习笔记4:深入理解实体与JPA #### 实体的概念与作用 实体,在企业级Java开发中,特别是EJB(Enterprise JavaBeans)框架下,指的是具有持久化能力的POJO(Plain Old Java Object)类。不同于实体Bean...
**EJB3.0 学习笔记** EJB(Enterprise JavaBeans)是Java EE平台中的核心组件,用于构建可扩展的、安全的、事务处理的分布式应用程序。EJB3.0是EJB的一个重大更新,引入了许多改进,使得开发过程更为简化,降低了...
EJB 3.0 版本引入了许多改进,简化了API,降低了学习曲线,使其更易于使用。 在MVC(模型-视图-控制器)架构中,EJB 主要用于开发业务层。它负责处理数据和业务逻辑,而视图层则展示数据,控制器则协调视图和模型...
【EJB学习笔记】 EJB,全称为Enterprise Java Beans,是Java平台上的一个标准,用于开发和部署服务器端的分布式组件。它基于Java语言,为创建高效能、安全且可扩展的企业级应用提供了框架。EJB规范由Java ...
标题"j2ee笔记--很有用的东西"表明这是一份关于J2EE技术的学习资料,可能包含了开发者在学习或工作中需要的重要知识点,对于面试准备或是日常开发工作都有很大的帮助。 描述"j2ee笔记--当你面试JAVA程序员的时候...
从最初的EJB 1.0到EJB 2.x,再到EJB 3.0,其复杂性和学习曲线逐渐降低。EJB 3.0引入了注解,极大地简化了代码,并且与JPA、JSF等其他Java EE技术更好地集成。最新的EJB 3.2版本继续优化了API,提高了开发效率。 **...