将JBoss下开发的EJB3.0数据库应用迁移到WebLogic10.3的注意事项

本文详细介绍了从JBoss迁移到Weblogic10.3过程中遇到的问题及解决方案,包括EJB3.0客户端配置调整、数据源配置差异、JPQL语法修正以及WebService发布路径的不同。

之前的EJB3.0及WebService开发是在JBoss下的,现在把项目迁移到Weblogic10.3下,发现会出现很多莫名其妙的问题。

 

1.EJB3.0客户端调用

在调用JBoss开发的EJB3.0的客户端上,需要配置一个名为jndi.proterties的文件,其内容包括:

java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces

#服务所在的ip地址,可以设为其它ip
java.naming.provider.url=IP地址

 

而如果EJB3.0是在Weblogic10.3下开发的,则要将第二句改为:
java.naming.factory.url.pkgs=weblogic.jndi.WLInitialContextFactory


2.数据源配置

JBoss下配置的数据源主要是在JBoss_Home\server\default\deploy目录下的xxx-xxx-ds.xml下进行的,只要在项目的persistence.xml下配置相应的JNDI即可。

在Weblogic10.3下,则需要在控制台的“服务-JDBC-数据源”中新建数据源(包括JNDI、数据库产品、数据库驱动、数据库帐号密码、哪个数据库等……),配置完后还要修改项目的persistence.xml,即在其中添加:

<provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider><!--这句好像可以不加的-->

<property name="openjpa.ConnectionURL" value="数据库连接URL"></property>
<property name="openjpa.ConnectionUserName" value="数据库帐号"></property>
<property name="openjpa.ConnectionPassword" value="数据库口令"></property> 

<property name="openjpa.ConnectionDriverName" value="数据库驱动类名" />

 

缺少上面4句可能会引发org.apache.openjpa.persistence.ArgumentException: A JDBC Driver or DataSource class name must be specified in the ConnectionDriverName property.的异常。

 

3.JPQL

在JBoss下正常运行的JPQL,放到Weblogic10.3下却总是会有奇怪的异常,如

EJB Exception: : <openjpa-1.1.1-SNAPSHOT-r422266:891341 nonfatal user error> org.apache.openjpa.persistence.ArgumentException: Encountered "from" at character 1, but expected: ["DELETE", "SELECT", "UPDATE"].

 

对于这个异常,容易理解:说JPQL语句缺少"DELETE", "SELECT", "UPDATE"等关键字。

原来在JBoss容器中,我们可以写这样的JPQL查询语句:

from Room r where r.roomType=?1

但在Weblogic下却必须写成:

select r from Room r where r.roomType=?1

 

还有这个更奇怪的异常:
Caused by: java.lang.Exception: org.apache.openjpa.lib.jdbc.ReportingSQLException: ORA-00955: 名称已由现有对象使用
 {stmnt 4024035 CREATE TABLE OPENJPA_SEQUENCE_TABLE (ID NUMBER NOT NULL, SEQUENCE_VALUE NUMBER, PRIMARY KEY (ID))} [code=955, state=42000]

 这个异常是发生在执行EntityManager的persist()方法。我上网查了一下,看到一位网友写道:

-------------------------------------------------------------

OpenJPA uses OPENJPA_SEQUENCE_TABLE to generate primary keys for entities that use datastore identity or application identity with auto-generation strategy. The table is created automatically when persistence.xml configuration specifies to build the schema.
<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>

The other option is to create the table directly via DDL:
CREATE TABLE openjpa_sequence_table (ID tinyint(4) NOT NULL, SEQUENCE_VALUE bigint(20) default NULL, PRIMARY KEY  (ID))

-------------------------------------------------------------

大概是说OpenJPA(Weblogic使用的JPA)在你使用自增的主键生成策略时,需要一张名为openjpa_sequence_table的数据表。如果你在persistence.xml中配置了<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>,那么这张表就会自动给你创建。你也可以采用其它方法,即通过DDL直接给数据库添加这张表。我们之所以抛出上面那异常,就是既没有配置<property name="openjpa.jdbc.SynchrnozieMappings" value="buildSchema"/>,也没有给数据库创建这张表。只要做了这一步,OpenJPA就能正常插入记录了。

 

4.WebService

在JBoss下发布的Web服务,其wsdl的名称与Weblogic10.3也有些不同。

前者默认是:机器:端口/项目名/xxx?wsdl,而后者却默认变成了:机器:端口/xxx/xxxService?wsdl

打开链接下载源码: https://pan.quark.cn/s/a4b39357ea24 QT框架是由Qt公司设计的一种跨平台C++图形用户界面应用程序开发工具包,该框架被广泛地应用于桌面电脑、移动设备以及嵌入式系统等领域。QTableView作为QT框架中的一个核心组件,其主要功能是用于展示表格形式的数据,并且常常与QAbstractItemModel或QSqlTableModel等模型类协同工作。在QTableView中嵌入自定义组件,例如按钮,能够实现更加多样化的用户交互功能。 在QT框架环境下,若想在QTableView的一列中嵌入两个按钮,我们需要掌握以下几个关键的技术要点: 1. **QTableView**:QTableView是QTableView类的一个实例,它提供了一个二维的表格视图界面,可以用来展示和编辑模型中的数据。QTableView能够显示由QAbstractItemModel子类所提供的数据,例如QStandardItemModel或QAbstractTableModel等。 2. **QTableWidgetItem**:在QTableView中,QTableWidgetItem是构成表格单元格的基本对象,它用于表示表格中每一行每一列的数据。在默认情况下,QTableView仅能展示文本信息,但通过继承QTableWidgetItem并重新绘制,我们可以实现自定义的内容,比如嵌入按钮。 3. **自定义视图项**:若要在单元格内部嵌入两个按钮,我们需要开发一个自定义的QTableWidgetItem子类,该子类中包含两个QPushButton。这个子类需要重写paintEvent()方法以绘制按钮,并且实现必要的信号和槽机制来处理按...
内容概要:本文系统研究了LLC谐振变换器的变频移相混合控制模型,并基于Simulink平台进行了完整的仿真实现。文章首先阐述了LLC谐振变换器在高频高效电源转换中的工作原理与技术优势,重点提出了一种融合变频控制与移相控制的混合调控策略,旨在拓宽输出调节范围并提升系统的动态响应能力与运行效率。通过建立精确的系统数学模型,设计了复合控制框图,并在Simulink中搭建仿真系统,全面验证了该控制策略在不同负载条件和输入电压波动下的稳定性、效率表现及软开关实现能力。仿真结果表明,所提出的混合控制方法能有效降低开关损耗,提高能量转换效率,具备良好的工程应用前景。; 适合人群:具备电力电子技术、自动控制理论基础,熟悉Simulink仿真环境,从事高频电源变换器、谐振变换器设计与优化的研究生、科研人员及电力电子领域工程技术人员。; 使用场景及目标:①用于高性能LLC谐振变换器控制系统的设计与动态性能优化;②为软开关技术在电力电子变换器中的应用提供仿真验证平台;③支撑相关课题的科研论文撰写、项目开发与创新方案验证。; 阅读建议:建议读者结合Simulink仿真模型文件进行同步操作,深入理解变频与移相控制的协调机制、控制环路设计及关键参数整定方法,重点关注软开关实现条件与系统效率优化路径,以促进理论研究向实际工程应用的转化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值