0

我有以下 JPA 代码,检查了所有值(ticket包含一个有效的 bean,它没有异常结束等)它被执行,它没有抛出任何异常,但最终没有数据写入表中。

我还尝试从表中检索一个 bean,它也“有效”(它是空的,所以没有返回数据)。

设置是

  • JBoss 6.1 最终版

  • SQLServer 2008 Express(来自 MS 的驱动程序 SQL JDBC 3)

持久化代码:

public String saveTicket() {
  System.out.println("Controller saveTicket() ");
  EntityManagerFactory factory = Persistence.createEntityManagerFactory("GesMan"); /* I know it would be better to share a single instance of factory, this is just for testing */
  EntityManager entityMan = factory.createEntityManager();
  entityMan.persist(this.ticket);
  entityMan.close();
}

持久性单位是

<?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="GesMan" transaction-type="JTA">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <jta-data-source>java:/GesManDS</jta-data-source>
    <class>es.caib.gesma.gesman.Ticket</class>
    <properties>
      <property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect"/>
      <property name="hibernate.transaction.manager_lookup_class"
      value="org.hibernate.transaction.JBossTransactionManagerLookup"/>
      <property name="hibernate.show_sql" value="true"/>
    </properties>
  </persistence-unit>
</persistence>

数据源

<datasources>
  <local-tx-datasource>
    <jndi-name>GesManDS</jndi-name>
    <connection-url>jdbc:sqlserver://spsigeswnt14.caib.es:1433;DatabaseName=TEST_GESMAN</connection-url>
    <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
    <user-name>thisis</user-name>
    <password>notthepassword</password>
    <check-valid-connection-sql>SELECT * FROM dbo.Ticket</check-valid-connection-sql>
    <metadata>
      <type-mapping>MS SQLSERVER</type-mapping>
    </metadata>
  </local-tx-datasource>
</datasources>
4

2 回答 2

0

调用entityMan.flush()transaction.commit()关闭它之前,否则它将丢弃所有在关闭时排队的更改。

于 2012-05-14T12:28:57.583 回答
0

最后,看起来我使用了错误的方法....在 JBoss 中,您不能(更好地说,我无法访问)直接访问 JPA(就像您在 JSE 中所做的那样)。

我结束了创建 EJB(带有事务)并在那里传递所有 JPA 逻辑。

PS:当然,如果我错了,请告诉我(现在这更像是一个学术问题,但我还是想知道)

于 2012-05-14T13:51:53.943 回答