0

我正在尝试在 Mule Studio 中使用 Oracle 数据库连接器实现 XA 事务。当我尝试在 MuleStudio 服务器上部署这个 mule 应用程序时,我遇到了异常。

例外:

“引起:org.springframework.beans.NotWritablePropertyException:bean类[oracle.jdbc.xa.client.OracleXADataSource]的无效属性'url':bean属性'url'不可写或具有无效的setter方法。是否参数setter 的类型是否与 getter 的返回类型匹配?”

骡配置xml文件:

<jdbc-ee:oracle-data-source name="Oracle_Data_Source" user="system" password="manager" url="jdbc:oracle:thin:@//localhost:1521/xe" transactionIsolation="UNSPECIFIED" doc:name="Oracle Data Source"/>
<jdbc-ee:connector name="Database" dataSource-ref="oracleJdbcBean" validateConnections="true" queryTimeout="-1" pollingFrequency="0" doc:name="Database"/>
<jbossts:transaction-manager doc:name="Transaction Manager"/>
<spring:beans>
    <spring:bean id="oracleJdbcBean" name="oracleJdbcBean" class="oracle.jdbc.xa.client.OracleXADataSource">
        <spring:property name="user" value="system"/>
        <spring:property name="password" value="manager"/>
        <spring:property name="url" value="jdbc:oracle:thin:@localhost:1521:xe"/>
    </spring:bean>
</spring:beans>
<flow name="oraclexatransactionFlow1" doc:name="oraclexatransactionFlow1">
    <http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="8082" path="testTable" doc:name="HTTP"/>
    <ee:xa-transactional action="ALWAYS_BEGIN" doc:name="Transactional">
        <jdbc-ee:outbound-endpoint exchange-pattern="request-response" queryKey="testQuery" queryTimeout="-1" connector-ref="Database" doc:name="Database">
            <xa-transaction action="ALWAYS_JOIN"/>
            <jdbc-ee:query key="testQuery" value="select * from test"/>
        </jdbc-ee:outbound-endpoint>
    </ee:xa-transactional>
</flow>

我已按照其他应用程序的上述配置使 xa 事务与 oracle 数据库一起使用,但我得到了不同的异常,如下所示:

引起:org.xml.sax.SAXParseException;行号:195;列号:55;cvc-complex-type.2.4.a:发现以元素“xa-transaction”开头的无效内容。'{" http://www.mulesoft.org/schema/mule/jdbc ":abstract-query}' 之一是预期的。

如果我配置有任何错误,请纠正我。

4

2 回答 2

0

“URL”的大写为我解决了第一个问题,即,

<spring:property name="URL" value="jdbc:oracle:thin:@localhost:1521:xe" />

第二个问题通过在查询之前放置“xa-transaction”元素得到解决,如下所示。

<jdbc-ee:outbound-endpoint exchange-pattern="request-response" queryKey="testQuery" queryTimeout="-1" connector-ref="Database" doc:name="Database"> 
<xa-transaction action="NONE" /> 
<jdbc-ee:query key="testQuery" value="select * from test" /> 

于 2013-11-15T07:43:23.157 回答
0

Url property should probably be

<spring:property name="url" value="jdbc:oracle:thin:@//localhost:1521/XE"/>
于 2013-11-15T03:28:28.247 回答