无法使用 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 ...>
可能是缺乏知识,但我无法检测到我的应用程序正在使用哪个数据库。 来自 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 ...>