[英]Could not open JPA EntityManager for transaction (using LocalContainerEntityManagerFactoryBean)
我在测试时看到了这个。 我确信数据库连接正在建立(或尝试),因为它在我没有包含密码时最初发出错误,然后它抱怨因为该名称的数据库不存在。 一旦我创建了数据库,它就给了我这个错误:
$ mvn clean test
...
Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 2.317 sec <<< FAILURE!
testGetAccounts(com.oreilly.repositories.JpaAccountRepositoryTest) Time elapsed: 0.104 sec <<< ERROR!
org.springframework.transaction.CannotCreateTransactionException: Could not open JPA EntityManager for transaction; nested exception is java.lang.NoSuchMethodError: org.hibernate.Session.getFlushMode()Lorg/hibernate/FlushMode;
at org.springframework.orm.jpa.JpaTransactionManager.doBegin(JpaTransactionManager.java:431)
at org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:373)
at org.springframework.test.context.transaction.TransactionContext.startTransaction(TransactionContext.java:98)
...
以下是我的配置文件:
@Configuration
@ComponentScan(basePackages = "com.oreilly")
@PropertySource("classpath:prod.properties")
@EnableTransactionManagement
public class AppConfig {
@Autowired
private Environment env;
@Bean
public DataSource dataSource() {
BasicDataSource dataSource = new BasicDataSource();
dataSource.setDriverClassName(env.getProperty("db.driver"));
dataSource.setUrl(env.getProperty("db.url"));
dataSource.setUsername(env.getProperty("db.user"));
dataSource.setPassword(env.getProperty("db.pass"));
return dataSource;
}
@Bean
public JpaVendorAdapter jpaVendorAdapter() {
HibernateJpaVendorAdapter adapter = new HibernateJpaVendorAdapter();
adapter.setShowSql(true);
adapter.setGenerateDdl(true);
adapter.setDatabase(Database.MYSQL);
return adapter;
}
@Bean
public LocalContainerEntityManagerFactoryBean entityManagerFactory(
DataSource dataSource, JpaVendorAdapter jpaVendorAdapter) {
Properties props = new Properties();
props.setProperty("hibernate.format_sql", String.valueOf(true));
LocalContainerEntityManagerFactoryBean emf =
new LocalContainerEntityManagerFactoryBean();
emf.setDataSource(dataSource);
emf.setPackagesToScan("com.oreilly.entities");
emf.setJpaVendorAdapter(jpaVendorAdapter);
emf.setJpaProperties(props);
return emf;
}
@Bean
public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
return new JpaTransactionManager(emf);
}
@Bean
public BeanPostProcessor persistenceTranslation() {
return new PersistenceExceptionTranslationPostProcessor();
}
}
如果它有帮助,很高兴包含更多代码。 我可以使用相同的凭据成功登录到我的mysql控制台,数据库在那里:
$ mysql -uroot -p spring
Enter password:
...
mysql> show databases;
+-----------------------+
| Database |
+-----------------------+
| ... |
| spring |
+-----------------------+
10 rows in set (0.00 sec)
我正在关注一个野生动物园书籍视频课程,这对JPA来说非常新鲜。 几乎只是采取了他们的代码仍然得到错误,所以很难知道我应该质疑哪部分代码。
UPDATE
这是我正在运行的测试。 我现在正在运行一个测试,否则我的控制台会遇到错误。 我也将在下面添加存储库代码:
JpaAccountRepositoryTest.java
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = AppConfig.class)
@Transactional
public class JpaAccountRepositoryTest {
@Autowired
private AccountRepository repository;
@Test
public void testGetAccounts() throws Exception {
List<Account> accounts = repository.getAccounts();
assertThat(accounts.size(), is(3));
}
// @Test
// public void testGetAccount() throws Exception {
// ...
JpaAccountRepository.java
@Repository
public class JpaAccountRepository implements AccountRepository {
private long nextId = 4;
@PersistenceContext
private EntityManager entityManager;
public List<Account> getAccounts() {
return entityManager.createQuery("select a from Account a", Account.class)
.getResultList();
}
public Account getAccount(Long id) {
...
Spring JpaTransactionManager需要一些其他版本的Hibernate,因为Session.getFlushMode()似乎缺失了。
根据这个答案,如果您使用的是旧版本的Spring,他们建议将Hibernate降级为hibernate-core-5.1.0.Final.jar。
检查你的依赖图,看看是否有什么东西覆盖了Hibernate版本。
为什么在测试类中使用@Transaction
。 使用可以使用@DataJpaTest
或@SpringBootTest
注释,大多数情况下更喜欢@DataJpaTest.
此问题看起来像Jar冲突。 您可以尝试降级到hibernate-core-5.1.0。 如果没有,请使用maven-enforcer插件创建依赖关系收敛分析,以确保您没有与传递依赖关系发生冲突。
更换
@Autowired
private AccountRepository repository;
同
@Autowired
private JpaAccountRepository repository;
在您的JpaAccountRepositoryTest类中
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.