Spring Data REST,无法保存,可以选择

时间:2016-02-03 21:09:18

标签: spring hibernate jpa spring-data spring-data-rest

我很困惑为什么我的Spring Data REST代码正在运行,但现在不再适用了。可能是一个配置问题,但我不能指出什么。当我使用AJAX发布到端点时,我收到500错误 - java.lang.IllegalArgumentException: argument type mismatch。当我从独立java中尝试repository.save()时,我得不到任何回复。另一方面,当我执行访问我的API或调用repository.find()时,我可以看到Hibernate显示选择正在发生。所以我知道我的数据库是连接的。此外,我使用的是Flyway,这些脚本可以毫无问题地插入。

我使用Spring-Boot-Starter for Data-REST,Data-JPA和thymeleaf,版本1.2.1.RELEASE。我认识到这可能是一个版本问题,但我一直在这里保持最终与Spring-Security-Kerberos集成,我知道它与Spring-Boot版本一起使用。至少,我还没有使用它来使用更高版本的Spring-Boot。

我注意到的一些事情可能与否有关:

  • @Transactional位于我的@RestRepositoryResource上方没有任何区别
  • 致电repository.save()时,返回的实体ID保持为0(我在我的实体上自动生成)
  • 我的所有实体都存在问题,包括没有任何关系的实体
  • 我从我的一个实体中删除了unique = true并不重要

我的一个存储库接口

@RepositoryRestResource(collectionResourceRel = "shifts", path = "shifts")
public interface ShiftRepository extends PagingAndSortingRepository<Shift, Long> {
    List<Shift> findBySiteId(@Param("siteId") String siteId);
    Shift findByShiftCode(@Param("shiftCode") String shiftCode);
}

我的存储库配置组件

@Component
public class RepositoryConfigDev {
    @Value("${spring.datasource.driver-class-name}")
    private String driverClassName;
    @Value("${spring.datasource.url}")
    private String url;
    @Value("${spring.datasource.username}")
    private String username;
    @Value("${spring.datasource.password}")
    private String password;

    @Bean
    EventHandler eventHandler() {
        return new EventHandler();
    }

    @Bean
    DataSource dataSource() {
        DriverManagerDataSource ds = new DriverManagerDataSource();
        ds.setDriverClassName(driverClassName);
        ds.setUrl(url);
        ds.setUsername(username);
        ds.setPassword(password);
        return ds;
    }

    @Bean
    public JpaVendorAdapter jpaVendorAdapter() {
        HibernateJpaVendorAdapter adapter = new HibernateJpaVendorAdapter();
        adapter.setDatabase(Database.SQL_SERVER);
        adapter.setDatabasePlatform("org.hibernate.dialect.SQLServer2012Dialect");
        adapter.setShowSql(true);
        adapter.setGenerateDdl(false);
        return adapter;
    }


    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean emfb = new LocalContainerEntityManagerFactoryBean();
        emfb.setJpaVendorAdapter(jpaVendorAdapter());
        emfb.setDataSource(dataSource());
        emfb.setPackagesToScan("package.model");
        emfb.afterPropertiesSet();
        return emfb;
    }

    @Bean
    public PlatformTransactionManager transactionManager() {
        JpaTransactionManager txManager = new JpaTransactionManager();
        txManager.setEntityManagerFactory(entityManagerFactory().getObject());
        txManager.setRollbackOnCommitFailure(true);
        return txManager;
    }

}

1 个答案:

答案 0 :(得分:0)

所以在从头开始重建之后,我弄清楚我做错了什么。问题发生在@RepositoryEventHandler。因为我最初宣布该课程为

@RepositoryEventHandler(value={Class1.class, Class2.class})
public class RepoEvents {
    ....
}

什么时候应该

@RepositoryEventHandler
public class RepoEvents {
    @HandleBeforeCreate(Class1.class)
    public void beforeCreate1(Class1 c) { ... }

    @HandleBeforeCreate(Class2.class)
    public void beforeCreate2(Class2 c) { ... }
}