Hibernate JPA создать таблицу тип = InnoDB Проблема - PullRequest
9 голосов
/ 17 августа 2011

У меня есть проект EJB, развернутый на JBoss с некоторыми классами сущностей.

Как только я разверну EJB, Jboss дает мне следующее исключение:

create table service_db (id integer not null auto_increment, ipAddress varchar(255),      
primary key (id)) type=InnoDB
Unsuccessful: create table service_db (id integer not null auto_increment, 
ipAddress varchar(255), primary key (id)) type=InnoDB
2011-08-17 11:38:59,997 ERROR [org.hibernate.tool.hbm2ddl.SchemaExport] You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'type=InnoDB' at line 1....

Разве это не должно быть двигатель = InnoDB вместо типа?Я попытался выполнить это утверждение в MySQL без удачи (та же ошибка).Если я удаляю или заменяю тип двигателем, он работает.

Мой вопрос: кто я могу это изменить?

Вот мой файл persistance.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="default">

    <jta-data-source>java:/DUMMY_DS</jta-data-source>
    <properties>
        <property name="hibernate.hbm2ddl.auto" value="create" />
        <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect" />
    </properties>

</persistence-unit>

и в случае важности XML-файла источника данных:

<datasources>
 <local-tx-datasource>
  <jndi-name>DUMMY_DS</jndi-name>

   <connection-url>jdbc:mysql://localhost/cargosoft</connection-url>
   <driver-class>com.mysql.jdbc.Driver</driver-class>
   <user-name>hauke</user-name>
   <password>******</password>
   <min-pool-size>5</min-pool-size>
   <max-pool-size>20</max-pool-size>
   <idle-timeout-minutes>10</idle-timeout-minutes>
   <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>     
   <valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLValidConnectionChecker</valid-connection-checker-class-name>
  </local-tx-datasource>
</datasources>

Спасибо за вашу помощь.

Хауке

1 Ответ

42 голосов
/ 17 августа 2011

Используйте MySQL5InnoDBDialect вместо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...