最近想想,成为Javaeye的会员已经有年头了,但是没有在上面发表过一篇文章,感觉惭愧,做了这么多年的程序,一直没有把自己的一些经验和想法和大家一起分享。
我在一家中小软件企业里面负责公司的技术,脑子里面成天想的是如何建立一套符合自己公司业务的技术框架,虽然公司小,但是项目不小,我们在为一家煤炭企业做ERP,系统的部署环境比较复杂,数据库是集群,web中间件也要集群,此时普通的技术方案和轻量级框架就不能满足了,我就想到了EJB3.0 ,我在网上找到了一篇讲述两者结合的文章,但是写的不是很清楚,给出的代码,我进行了加工和调整,才跑起来,不多说了,看看下面的代码:
代码1:
代码2:
此时我的ejb代码已经完成,我是用M2来管理我的工程,进行打包编译,不需要产生客户端程序。我用的测试服务器是Jboss4.2.3的版本,下来我们要发布我们的ejb了,此时先要编写oracle-ds.xml:
然后我们就要编写JAP相应的持久化文件persistence.xml名称应该是不能变动的,我没有测试过,但是文档描述文件名称是不能变的
此时,相应的persistence.xml文件一定要放在已经打好包的ejb里面,在打好的ejb包里,根目录下有META-INF目录,放在里面就可以了,今天先写到这里
我在一家中小软件企业里面负责公司的技术,脑子里面成天想的是如何建立一套符合自己公司业务的技术框架,虽然公司小,但是项目不小,我们在为一家煤炭企业做ERP,系统的部署环境比较复杂,数据库是集群,web中间件也要集群,此时普通的技术方案和轻量级框架就不能满足了,我就想到了EJB3.0 ,我在网上找到了一篇讲述两者结合的文章,但是写的不是很清楚,给出的代码,我进行了加工和调整,才跑起来,不多说了,看看下面的代码:
代码1:
package com.ejb3.service; import com.ejb3.domain.Customer; import java.util.Collection; import javax.ejb.Stateless; import javax.jws.WebService; import javax.jws.soap.SOAPBinding; import javax.persistence.EntityManager; import javax.persistence.PersistenceContext; import javax.persistence.Query; import javax.jws.WebMethod; @Stateless @Remote( { CustomerService.class }) public class CustomerServiceImpl implements CustomerService { //unitName是指你数据库的用户名,我用的是oracle10g,如果是别的数据库就是数据库名称 @PersistenceContext(unitName="ERP") private EntityManager manager; public Customer create(Customer info) { this.manager.persist(info); return info; } public Customer update(Customer info) { return this.manager.merge(info); } public void remove(Long customerId) { this.manager.remove(this.manager.getReference(Customer.class, customerId)); } public Collection<Customer> findAll() { Query query = this.manager.createQuery("SELECT c FROM Customer c"); return query.getResultList(); } public Customer[] findAllAsArray() { Collection<Customer> collection = findAll(); return (Customer[]) collection.toArray(new Customer[collection.size()]); } public Customer findByPrimaryKey(Long customerId) { return (Customer) this.manager.find(Customer.class, customerId); }
代码2:
package com.ejb3.service; import com.ejb.domain.Customer; import java.util.Collection; import javax.ejb.Local; import javax.ejb.Remote; public interface CustomerService { Customer create(Customer info); Customer update(Customer info); void remove(Long customerId); Collection<Customer> findAll(); Customer[] findAllAsArray(); Customer findByPrimaryKey(Long customerId); }
此时我的ejb代码已经完成,我是用M2来管理我的工程,进行打包编译,不需要产生客户端程序。我用的测试服务器是Jboss4.2.3的版本,下来我们要发布我们的ejb了,此时先要编写oracle-ds.xml:
<?xml version="1.0" encoding="UTF-8"?> <datasources> <local-tx-datasource> <jndi-name>OracleDS</jndi-name> <connection-url>jdbc:oracle:thin:@192.168.1.222:1521:oracle</connection-url> <driver-class>oracle.jdbc.driver.OracleDriver</driver-class> <user-name>ERP</user-name> <password>ERP</password> <SetBigStringTryClob>true</SetBigStringTryClob> <exception-sorter-class-name> org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</exception-sorter-class-name> <metadata> <type-mapping>Oracle9i</type-mapping> </metadata> </local-tx-datasource> </datasources>
然后我们就要编写JAP相应的持久化文件persistence.xml名称应该是不能变动的,我没有测试过,但是文档描述文件名称是不能变的
<?xml version="1.0" encoding="UTF-8"?> <persistence version="1.0" 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"> <persistence-unit name="ERP" transaction-type="JTA"> <jta-data-source>java:/OracleDS</jta-data-source> <properties> <property name="hibernate.hbm2ddl.auto" value="create-drop"/> </properties> </persistence-unit> </persistence>
此时,相应的persistence.xml文件一定要放在已经打好包的ejb里面,在打好的ejb包里,根目录下有META-INF目录,放在里面就可以了,今天先写到这里