我们正在使用JPA 2.0
,我们在websphere中创建了数据源,并尝试通过J2SE应用程序访问数据库。我们收到无效的用户名和密码错误。如果我们在persistence.xml
中提供用户名和密码,则可以正常使用。
请有人解释一下,为什么我们必须在persistence.xml中提供数据库凭据,因为我们有数据源。
注意:数据源已成功创建且测试成功。
的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="Printer">
<jta-data-source>jdbc/TestDataSource</jta-data-source>
<properties>
<property name="openjpa.Optimistic" value="false" />
<property name="openjpa.LockManager" value="pessimistic" />
<property name="javax.persistence.jdbc.user" value="admin" />
<property name="javax.persistence.jdbc.password" value="admin#2" />
</properties>
</persistence-unit>
</persistence>
答案 0 :(得分:2)
似乎在websphere中未正确配置数据源。 Test the database connection通过websphere控制台验证配置。
DataSource有两种获取Connection
的方法。如果您通过属性提供凭据,那么您的jpa实现似乎使用DataSource.getConnection(String username, String password)
。
连接属性旨在用于Java SE环境。在JEE中,您应该更喜欢JNDI查找。请参阅JPA 2.0规范的8.2.1.9部分。
答案 1 :(得分:-2)
您无需在应用程序中指定凭据。只需通过JNDI访问您的数据库,指定您在WS中创建的数据源的名称。
一种方法是使用预配置的数据源配置持久性单元(请仔细检查它是否配置正确 - 测试功能在WS中可用)
<persistence-unit name="default" transaction-type="JTA">
<provider>
oracle.toplink.essentials.PersistenceProvider
</provider>
<jta-data-source>
jdbc/MyDataSource
</jta-data-source>
<properties>
<property name="toplink.logging.level" value="INFO"/>
</properties>
</persistence-unit>
如果未在应用程序容器端配置数据源,则可以在应用程序端自行设置。例如,您需要许多应用程序,每个应用程序都有自己的数据库连接配置。
<persistence-unit name="default" transaction-type="RESOURCE_LOCAL">
<provider>
oracle.toplink.essentials.PersistenceProvider
</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="toplink.logging.level" value="INFO"/>
<property name="toplink.jdbc.driver" value="oracle.jdbc.OracleDriver"/>
<property name="toplink.jdbc.url" value="jdbc:oracle:thin:@myhost:l521:MYSID"/>
<property name="toplink.jdbc.password" value="tiger"/>
<property name="toplink.jdbc.user" value="scott"/>
</properties>
</persistence-unit>
你的persistence.xml有两种方式的配置。删除不必要的代码,然后重试。