我有一個帶有休眠和jpa的彈簧啟動應(yīng)用程序。當(dāng)嘗試創(chuàng)建實體的新實例(通過任何一個或直接)時,一切似乎都很好(沒有錯誤,并且返回的實例正在增加),但是這些實例被保存到數(shù)據(jù)庫中,也不會在查詢到orm時返回(niether by norFooJpaRepositoryentityManageridJpaRepository.findAll()entityManager.find(FooImpl.class, id))我嘗試調(diào)用方法而不是 -> 拋出錯誤(無事務(wù))saveAndFlushsaveJpaRepository我嘗試手動刷新 ->相同的錯誤。entityManager我檢查了 的齊平模式 - >它是“自動”entityManager我嘗試直接使用 ->找不到任何實例entityManager.find(CourseImpl.class, id)我嘗試用->注釋服務(wù)方法沒有區(qū)別@Transactional我的實體:@Entity@Table(name = "foo")public class FooImpl implements Foo{ @Id @GeneratedValue private Long id; @Column private String someOtherValue; ... @Override public Long getId() { return id; } @Override public void setId(Long id) { this.id = id; }}我:Application.java@SpringBootApplication@EnableJpaRepositories@EnableTransactionManagement@EnableJpaAuditingpublic class Application extends SpringBootServletInitializer implements ApplicationContextAware { private static ApplicationContext applicationContext; @Override protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { return application.sources(Application.class); } @Bean @Primary @ConfigurationProperties(prefix = "spring.datasource") public javax.sql.DataSource primaryDataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver"); dataSource.setUsername("username"); dataSource.setPassword("n0tRea1Pasw0rd"); dataSource.setUrl("jdbc\\:mysql\\://localhost\\:3306/bar"); dataSource.setSchema("bar"); return dataSource; }
1 回答

郎朗坤
TA貢獻(xiàn)1921條經(jīng)驗 獲得超9個贊
問題是奇怪的默認(rèn)事務(wù)處理(JPA存儲庫將它們的方法包裝在 中,因此我是否也這樣做并不重要)。此問題已通過創(chuàng)建“自定義”事務(wù)管理器 Bean 得到解決。具體來說,這豐富了以下內(nèi)容:@TransactionalApplication.java
...
@Bean
public PlatformTransactionManager transactionManager() {
JpaTransactionManager transactionManager = new JpaTransactionManager();
transactionManager.setEntityManagerFactory(entityManagerFactoryBean().getObject());
return transactionManager;
}
...
添加回答
舉報
0/150
提交
取消