gpt4 book ai didi

java - 是否有 Spring ORM/JPA 继任者或替代 TopLinkJpaVendorAdapter?

转载 作者:行者123 更新时间:2023-11-30 08:56:59 25 4
gpt4 key购买 nike

这似乎是非常基本的东西,我应该能够很容易地找到它,但我一直没能找到答案!

在 Spring 3.2.4 文档中,表示移除了供应商对 Toplink Essentials 的支持: http://docs.spring.io/autorepo/docs/spring-framework/3.2.4.RELEASE_to_4.0.0.M3/changes/pkg_org.springframework.orm.jpa.vendor.html

但是我在任何地方都找不到使用这个类的替代方法 - 所有使用 Spring 配置 Toplink 的示例似乎都来自 Spring 2.5 左右的时间,例如https://community.oracle.com/thread/597157

谁能告诉我现在为 Toplink JPA 实现定义 spring 应用程序上下文的公认方法是什么?

我正在使用:

  • Spring (4.1.4)
  • Toplink 基础知识(2.1-60f)
  • 嵌入式 Derby 数据库 (10.11.1.1)
  • Tomcat (8.0.18)

我当前的代码和配置设置如下所示,它可以工作——从这个意义上说,当我在我的模拟网络应用程序中转到 /help 时,数据库被创建了——但它没有创建我的实体表会自动生成,这就是我现在主要想找到的解决方案。我怀疑这是因为下面定义的所有内容都是一个简单的 JDBC 数据源,而不是一个适当的 JPA 实体管理器工厂,它可以更进一步并自动为我创建我的所有实体。

在我将其迁移到 WAR 并将其部署到 Tomcat 之前,我有一个使用相同 persistence.xml 的独立 java 应用程序并且它工作得很好(自动创建数据库和实体表是)。现在我已经转向 Web 应用程序并将 Spring 加入其中,而不是太多:-(

基本上,我知道我需要在我的 Spring 应用程序上下文中的某处指定 create-tables(或 generateDdl=true),就像在 persistence 中所做的那样.xml 文件,但我不确定如何在没有 TopLinkJpaVendorAdapter 类的情况下执行此操作(请参阅 applicationContext.xml 中注释掉的元素)下面。

Spring 实体管理器工厂似乎引用了 persistence.xml 中定义的持久性单元名称,但似乎没有注意到其中定义的任何其他内容 - 有没有办法我可以让 Spring 从 persistence.xml 中定义的内容获取这些其他设置(即 Toplink 实体管理器工厂提供程序类和 JDBC 详细信息等)?或者,如果 Spring 放弃了它的供应商实现,而只使用 Eclipselink 或 Hibernate,是否值得继续沿用 Toplink 的道路? (顺便说一句,有谁知道为什么这个实现类首先被删除?)

META-INF/persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.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 persistence_1_0.xsd">

<persistence-unit name="xyz-jpa" transaction-type="RESOURCE_LOCAL">

<provider>oracle.toplink.essentials.ejb.cmp3.EntityManagerFactoryProvider</provider>

<class>org.xyz.MyDbEntity</class>

<properties>
<!--
<property name="toplink.jdbc.user" value="league"/>
<property name="toplink.jdbc.password" value="league"/>
-->
<property name="toplink.jdbc.url" value="jdbc:derby:xyz;create=true"/>
<property name="toplink.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
<property name="toplink.ddl-generation" value="create-tables"/>
</properties>

</persistence-unit>
</persistence>

WEB-INF/spring/applicationContext.xml:

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">

<mvc:annotation-driven/>
<context:component-scan base-package="org.xyz.web" />

<!-- <context:spring-configured /> -->
<context:load-time-weaver aspectj-weaving="autodetect"/>

<!--+
| (1) Define a Spring JDBC datasource wrapper for an embedded Derby database
+-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.apache.derby.jdbc.EmbeddedDriver"/>
<property name="url" value="jdbc:derby:xyz;create=true"/>
</bean>

<!--+
| (2) Define a Spring ORM entity manager factory bean wrapper for a Toplink JPA implementation
+-->
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="xyz-jpa"/>
<property name="dataSource" ref="dataSource"/>
<!--
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.TopLinkJpaVendorAdapter">
<property name="showSql" value="true"/>
<property name="generateDdl" value="true"/>
<property name="databasePlatform" value="oracle.toplink.essentials.platform.database.DerbyPlatform"/>
</bean>
</property>

<property name="jpaProperties">
<props>
<prop key="toplink.weaving">static</prop>
<prop key="toplink.logging.level">FINEST</prop>
<prop key="toplink.ddl-generation">create-tables</prop>
<prop key="toplink.ddl-generation.output-mode">both</prop>
<prop key="toplink.drop-ddl-jdbc-file-name">generated_jpa.sql</prop>
</props>
</property>

<property name="loadTimeWeaver">
<bean class="org.springframework.instrument.classloading.tomcat.TomcatInstrumentableClassLoader" />
</property>
-->
</bean>

<!-- (3) Define a Spring ORM transaction manager wrapper for (1) and (2) -->
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
<property name="dataSource" ref="dataSource"/>
</bean>


<bean id="helpController" class="org.xyz.web.HelpController">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>


</beans>

WEB-INF/web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">

<display-name>XYZ</display-name>

<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/applicationContext.xml</param-value>
</context-param>

<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value></param-value> <!-- No servlet specific context config file (i.e. "dispatcher-servlet.xml") => use applicationContext.xml -->
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

</web-app>

META-INF/context.xml:

<Context path="/" reloadable="true">
<Loader loaderClass="org.springframework.instrument.classloading.tomcat.TomcatInstrumentableClassLoader"/>
</Context>

org.xyz.web.HelpController:

@RestController
public class HelpController {

private EntityManagerFactory entityManagerFactory;

public HelpController() {
}


public EntityManagerFactory getEntityManagerFactory() {
return entityManagerFactory;
}


public void setEntityManagerFactory(EntityManagerFactory entityManagerFactory) {
this.entityManagerFactory = entityManagerFactory;
}


@RequestMapping( value="/help", produces=MediaType.TEXT_HTML_VALUE )
public @ResponseBody String getHelp() {

EntityManager entityManager = entityManagerFactory.createEntityManager();

return "Helpy Mc Help-Help";
}
}

最佳答案

来自Wikipedia page在 TopLink 上:

In 2007, TopLink source code was donated to the Eclipse Foundation and the EclipseLink project was born.

因此,TopLink 的开源版本现在以 EclipseLink 的形式存在,它是 JPA 2.0 的引用实现。

除非您有使用 TopLink Essentials 的非常具体的原因(这似乎不太可能,因为您使用的是最新版本的 Spring 框架和 Tomcat),否则您应该使用其他 JPA 实现之一。

关于java - 是否有 Spring ORM/JPA 继任者或替代 TopLinkJpaVendorAdapter?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28334556/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com