gpt4 book ai didi

java - 使用 entityManager.persist(Object) 插入 ... 值;

转载 作者:搜寻专家 更新时间:2023-11-01 01:55:32 26 4
gpt4 key购买 nike

public void miseAJourTranscoIdCroisiere(Integer idCroisiereKaravel, String idCroisiereArmateur, TypeArmateur typeArmateur) {
IdCroisiereKaravelArmateur idRelationship = new IdCroisiereKaravelArmateur();

idRelationship.setIdCroisiereKaravel(idCroisiereKaravel);
idRelationship.setIdCroisiereArmateur(idCroisiereArmateur);
idRelationship.setTypeArmateur(typeArmateur);

entityManager.persist(idRelationship);
}

这个代码片段应该由它自己工作吗?它也不异常(exception)。但是它什么都不做。我对 Java 中的持久性非常困惑。

因为我不能用 hql 插入 ... 值,所以我应该直接用 jpa 来做,对吧?

我试过了in this way但我明白了

java.lang.IllegalStateException: Not allowed to create transaction on shared EntityManager - use Spring transactions or EJB CMT instead
at org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:198)
at $Proxy19.getTransaction(Unknown Source)
at com.karavel.connectivity.gateway.croisiere.common.repository.impl.CatalogueKaravelRepositoryImpl.miseAJourTranscoIdCroisiere(CatalogueKaravelRepositoryImpl.java:56)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:309)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:196)
at $Proxy23.miseAJourTranscoIdCroisiere(Unknown Source)
at com.karavel.connectivity.gateway.croisiere.controller.service.RechercherCroisiereController.getItineraireCroisiere(RechercherCroisiereController.java:385)
at com.karavel.connectivity.gateway.croisiere.controller.service.RechercherCroisiereController.obtenirListeCroisiere(RechercherCroisiereController.java:283)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:176)
at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:426)
at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:414)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:790)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:560)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.web.filter.AbstractRequestLoggingFilter.doFilterInternal(AbstractRequestLoggingFilter.java:193)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:291)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:662)

所以我考虑创建另一个 EntityManager 来执行此操作。但因为它不是静态方法,所以我不能使用 EntityManagerFactory。

在 ddbb 中做一个简单的插入会如此困惑吗?

如果我说的很愚蠢或者我混淆了概念,我很抱歉,但我在 Java 持久性和 Hibernate 方面有两天的经验。

编辑以显示我的类(class):

我确实需要一个事务,但我不能从一个共享的 EntityManager 中得到它(这是什么意思?)

我是否只需要一个 EntityManager 用于该方法?如果这样做,我就不能将 EntityManagerFactory 用作静态。

抱歉,这个架构不是我创建的。我刚刚开始使用 Spring 和 Hibernate,所以这里有一个很大的组合......

应用上下文:

<bean id="gateway.croisiere.catalogueKaravel.dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${gateway.croisiere.catalogueKaravel.driver.className}" />
<property name="url" value="${gateway.croisiere.catalogueKaravel.driver.url}" />
<property name="username" value="${gateway.croisiere.catalogueKaravel.driver.username}" />
<property name="password" value="${gateway.croisiere.catalogueKaravel.driver.password}" />
</bean>
<bean id="gateway.croisiere.catalogueKaravel.entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceXmlLocation" value="classpath:/catalogueKaravel-persistence.xml" />
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="generateDdl" value="${gateway.croisiere.catalogueKaravel.hibernate.hbm2ddl.auto}" />
<property name="databasePlatform" value="${gateway.croisiere.catalogueKaravel.hibernate.dialect}" />
<property name="showSql" value="${gateway.croisiere.catalogueKaravel.hibernate.show_sql}" />
</bean>
</property>
<property name="dataSource" ref="gateway.croisiere.catalogueKaravel.dataSource" />
<property name="persistenceUnitName" value="gateway-croisiere-catalogueKaravel-persitence-unit" />
</bean>
<bean id="gateway.croisiere.catalogueKaravel.transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="gateway.croisiere.catalogueKaravel.entityManagerFactory" />
<property name="defaultTimeout" value="${gateway.croisiere.catalogueKaravel.hibernate.transaction.timeout}" />
</bean>
<tx:annotation-driven transaction-manager="gateway.croisiere.catalogueKaravel.transactionManager" />persistence:
<persistence 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_1_0.xsd" version="1.0">
<persistence-unit name="gateway-croisiere-catalogueKaravel-persitence-unit" transaction-type="RESOURCE_LOCAL">
<class>com.karavel.connectivity.gateway.croisiere.common.domain.cataloguekaravel.IdCroisiereKaravelArmateur</class>
<class>com.karavel.connectivity.gateway.croisiere.common.domain.cataloguekaravel.CroisiereInfoCatalogueKaravel</class>
<class>com.karavel.connectivity.gateway.croisiere.common.domain.cataloguekaravel.CroisiereOffreItineraireCatalogueKaravel</class>
<class>com.karavel.connectivity.gateway.croisiere.common.domain.cataloguekaravel.EscaleCatalogueKaravel</class>
<class>com.karavel.connectivity.gateway.croisiere.common.domain.cataloguekaravel.CroisiereItineraireCatalogueKaravel</class>
</persistence-unit>
</persistence>

实体:

@Entity
@Table(name="transco_idcroisierekaravel_idcroisierearmateur")
public class IdCroisiereKaravelArmateur implements Serializable {

private static final long serialVersionUID = -2764921376397148157L;

@Id
@GeneratedValue
@Column(name="id")
private Integer id;

@Column(name="idCroisiereKaravel")
private Integer idCroisiereKaravel;

@Column(name="idCroisiereArmateur")
private String idCroisiereArmateur;

@Column(name="typeArmateur")
@Enumerated(EnumType.STRING)
private TypeArmateur typeArmateur;

public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

public Integer getIdCroisiereKaravel() {
return idCroisiereKaravel;
}

public void setIdCroisiereKaravel(Integer idCroisiereKaravel) {
this.idCroisiereKaravel = idCroisiereKaravel;
}

public String getIdCroisiereArmateur() {
return idCroisiereArmateur;
}

public void setIdCroisiereArmateur(String idCroisiereArmateur) {
this.idCroisiereArmateur = idCroisiereArmateur;
}

public TypeArmateur getTypeArmateur() {
return typeArmateur;
}

public void setTypeArmateur(TypeArmateur typeArmateur) {
this.typeArmateur = typeArmateur;
}
}

存储库

@SuppressWarnings("unchecked")
public class CatalogueKaravelRepositoryImpl implements CatalogueKaravelRepository {
@PersistenceContext(unitName="gateway-croisiere-catalogueKaravel-persitence-unit")
private EntityManager entityManager;

@Override
@Transactional
public void miseAJourTranscoIdCroisiere(Integer idCroisiereKaravel, String idCroisiereArmateur, TypeArmateur typeArmateur) {

IdCroisiereKaravelArmateur idRelationship = new IdCroisiereKaravelArmateur();

idRelationship.setIdCroisiereKaravel(idCroisiereKaravel);
idRelationship.setIdCroisiereArmateur(idCroisiereArmateur);
idRelationship.setTypeArmateur(typeArmateur);

EntityManager em = getEntityManager();

// begin transaction
em.getTransaction().begin();

// persist object - add to entity manager
em.persist(idRelationship);

// flush em - save to DB
em.flush();

// commit transaction at all
em.getTransaction().commit();
}
}

最佳答案

看起来您的问题很简单:它需要一个交易。你正在使用 Spring 。将 Spring 拖入持久化领域的主要原因是为了获得基于 AOP 的注入(inject)事务.. ?您应该能够注释您的方法 @Transaction 并在您的 applicationContext.xml 中或通过其他 Bootstrap 启动 TransactionManager。

关于java - 使用 entityManager.persist(Object) 插入 ... 值;,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10755717/

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