无法使用 JBoss 检测 JPA 使用的数据库

Can't detect Database used by JPA with JBoss

可能是缺乏知识,但我无法检测到我的应用程序正在使用哪个数据库。 来自 JBoss AS 的 standalone.xml 中的数据源和驱动程序如下所示:

<subsystem xmlns="urn:jboss:domain:datasources:1.0">
            <datasources>
                <datasource jta="true" jndi-name="java:/MySqlDS" pool-name="MySqlDS_Pool" enabled="true" use-java-context="true" use-ccm="true">
                    <connection-url>jdbc:mysql://localhost:3306/studadmin</connection-url>
                    <driver>com.mysql</driver>
                    <security>
                        <user-name>sa</user-name>
                        <password>sa</password>
                    </security>
                    <timeout>
                        <idle-timeout-minutes>0</idle-timeout-minutes>
                        <query-timeout>600</query-timeout>
                    </timeout>
                    <statement>
                        <prepared-statement-cache-size>100</prepared-statement-cache-size>
                        <share-prepared-statements>true</share-prepared-statements>
                    </statement>
                </datasource>
                <datasource jndi-name="java:jboss/datasources/ExampleDS" pool-name="ExampleDS" enabled="true" use-java-context="true">
                    <connection-url>jdbc:h2:mem:test;DB_CLOSE_DELAY=-1</connection-url>
                    <driver>h2</driver>
                    <security>
                        <user-name>sa</user-name>
                        <password>sa</password>
                    </security>
                </datasource>
                <drivers>
                    <driver name="com.mysql" module="com.mysql">
                        <driver-class>com.mysql.jdbc.Driver</driver-class>
                        <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
                    </driver>
                    <driver name="h2" module="com.h2database.h2">
                        <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
                    </driver>
                </drivers>
            </datasources>
        </subsystem>

这是我的 persistence.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="primary">
  <jta-data-source>java:jboss/datasources/studadminDS</jta-data-source>
  <properties>
   <property name="hibernate.hbm2ddl.auto" value="update" />
   <property name="hibernate.show_sql" value="true" />
  </properties>
 </persistence-unit>
 
</persistence>

我只是用这个方法从数据库中读取:

@PostConstruct
public void init() {
    students = new ListDataModel<Student>();
    students.setWrappedData(em.createNamedQuery("SelectStudents")
            .getResultList());
}

而这个将学生保存在数据库中:

public String saveStudent() {
    try {
        utx.begin();
    } catch (NotSupportedException e) {
        e.printStackTrace();
    } catch (SystemException e) {
        e.printStackTrace();
    }
    student = em.merge(student);
    em.persist(student);
    students.setWrappedData(em.createNamedQuery("SelectStudents")
            .getResultList());
    try {
        utx.commit();
    } catch (SecurityException e) {
        e.printStackTrace();
    } catch (IllegalStateException e) {
        e.printStackTrace();
    } catch (RollbackException e) {
        e.printStackTrace();
    } catch (HeuristicMixedException e) {
        e.printStackTrace();
    } catch (HeuristicRollbackException e) {
        e.printStackTrace();
    } catch (SystemException e) {
        e.printStackTrace();
    }
    return "studentList";
}

我在我的数据库中保存了一些新学生后,使用相应的facelet,成功列出了他们。但问题是,当我在我的 MySQL 数据库中查找时,没有新条目,尽管数据保存在某个地方,因为如果我部署我的应用程序,数据仍然可用。

那么我的应用程序正在使用哪个数据库很明显,或者是否可以检测到它?

您混淆了 JNDI 名称。

您的 standalone.xml 正在创建一个 JNDI 名称 java:/MySqlDS ,但是在 persistence.xml 中您引用了一个 JNDI 资源 java:jboss/datasources/studadminDS.

我建议您更改 standalone.xml:

...
<datasource jta="true" jndi-name="java:jboss/datasources/studadminDS" pool-name="MySqlDS_Pool" enabled="true" use-java-context="true" use-ccm="true">
...

在您的 standalone.xml 中声明休眠方言可能也会有所帮助:

     <datasource ...>
           <connection-property name="hibernate.dialect">
                    org.hibernate.dialect.MySQLDialect
            </connection-property>
      </datasource ...>