0

我正在将 glassfish jpa 应用程序移植到 jboss 并遇到此错误:

部署错误: 部署“persistence.unit:unitName=Avengers.war#AvengersPU”由于以下原因而出错:org.hiberna te.HibernateException:当没有可用连接时必须设置“hibernate.dialect”

可以使用 jboss 管理控制台成功测试连接,我可以手动登录到我的数据库,所以我对这个错误消息感到困惑。有人可以就我错过的配置提出建议吗?

这是我的mysql-ds.xml文件:

<datasources>
  <local-tx-datasource>
    <jndi-name>jdbc/thor_ds</jndi-name>
    <connection-url>jdbc:mysql://localhost:3306/thor</connection-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <user-name>apple</user-name>
    <password>apple</password>
    <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>   
    <metadata>
       <type-mapping>mySQL</type-mapping>
    </metadata>
  </local-tx-datasource>
</datasources>

和我的persistance.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.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_2_0.xsd">
  <persistence-unit name="AvengersPU" transaction-type="JTA">
    <!--<jta-data-source>jdbc/thor_ds</jta-data-source>-->
    <jta-data-source>java:/jdbc/thor_ds</jta-data-source>
    <class>avenger.Grouptable</class>
    <class>avenger.MyUser</class>
    <exclude-unlisted-classes>true</exclude-unlisted-classes>
    <properties>
    </properties>
  </persistence-unit>
</persistence>

编辑:按照 JMelnik 的说明,我的配置属性标签现在有:

<properties>
    <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
</properties>
4

1 回答 1

2

你应该在你的 persistence.xml 中设置你的数据库方言:

<properties>
    <property name="hibernate.dialect" value="org.hibernate.dialect.DIALECT" />
</properties>

将 DIALECT 替换为hibernate 支持的数据库方言列表中的方言。

于 2012-07-02T08:04:08.370 回答