1

最近我发现了 Spring Data Jpa。我无法使其正常工作的一件事是将异常转换为 Spring 的异常层次结构。

根据这个Spring Data JPA 强制 CGLib 代理到非存储库类<jpa:repositories />激活使用 @Repository 注释的 Spring bean 的持久性异常转换。这篇文章中的参考文档指向 spring-data-jpa 1.1.1。

但是当您查看 1.3.0 版的文档时,这一段已被删除。我也在@Repository尽可能地使用注释,但没有成功。

我的问题是:是否可以使用最近的 spring-data-jpa lib 1.3.0 版实现正确的异常翻译?

好的。我将在这里放置一些配置:

...

<bean id="myDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
  <property name="driverClass" value="oracle.jdbc.OracleDriver"/>
  <property name="jdbcUrl" value="jdbc:oracle:thin:@localhost:1521:pbase"/>
  <property name="user" value="sa"/>
  <property name="password" value="pass"/>
</bean>

<context:annotation-config/>

<bean id="myEmf" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="myDataSource"/>
    <property name="persistenceUnitName" value="prjPersistenceUnit"></property>
    <property name="persistenceXmlLocation" value="classpath:META-INF/mpersistence.xml"></property>
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.EclipseLinkJpaVendorAdapter"
              p:showSql="true"/>
    </property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="myEmf"/>
</bean>

<tx:annotation-driven/>

<jpa:repositories base-package="com.mycompany.repository" />

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="prjPersistenceUnit" transaction-type="RESOURCE_LOCAL">
        <description>Persistence unit which uses EclipseLink JPA 2.0 implementation.</description>
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <class>com.mycompany.Setting</class>
        <exclude-unlisted-classes>true</exclude-unlisted-classes>
        <properties>
            <property name="eclipselink.target-server" value="JBoss"/>
            <property name="eclipselink.target-database" value="Oracle10g"/>
            <property name="eclipselink.weaving" value="static"/>
        </properties>
    </persistence-unit>
</persistence>

我的仓库

@Repository
public interface TestRepository extends JpaRepository<Setting, Long> {

    Setting findByNamee(String name);
}

这里 findByNamee 应该引发一些 Spring 数据库异常,因为数据库中的一个真实属性是 name 而不是 namee。但我总是得到

Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.3.2.v20111125-r10461): org.eclipse.persistence.exceptions.DatabaseException

@Repository但是,当使用注释配置常规 Dao 对象时,一切都按预期工作。

我正在尝试使用 eclipseLink 2.3.2 在 Tomcat 6.0 上部署它。

4

2 回答 2

0

您必须将 EclipseLink Jpa 方言注入 EntityManagerFactory,因为异常翻译器在方言中。

于 2013-10-03T20:54:47.943 回答
0

您可以查看我从那时起在https://github.com/zagyi/examples/tree/master/spring-data-jpa发布的一些工作示例代码

于 2013-02-24T16:37:59.250 回答