Почему собственное весеннее обновление JPA загрузки дает PSQLException с postgres базой данных? - PullRequest
0 голосов
/ 11 февраля 2020

У меня есть этот класс сущностей:

@Entity
@Table(name = "inbox_inbox")
@Getter
@Setter
@TypeDef(name = "jsonb", typeClass = JsonBinaryType.class)
public class Inbox implements Serializable {

    @Id
    private int id;
    @Column(name = "created")
    private Date created;
    @Column(name = "modified")
    private Date modified;
    @Column(name = "status")
    private String status;
}

У меня есть этот репозиторий:

@Repository
public interface InboxRepository extends JpaRepository<Inbox, Integer> {

    List<Inbox> findInboxesByStatus(String status);

    @Modifying
    @Transactional
    @Query(value = "update inbox_inbox i set i.status = ?2 where i.id = ?1", nativeQuery = true)
    int setInboxStatusById(int id, String status);
}

Если я позвоню findInboxesByStatus(String status) с требуемым статусом, то это даст ожидаемый результат. Но при звонке setInboxStatusById() это дает мне исключение!

Я даю свою вызывающую часть здесь:

int updatedRows = inboxRepository.setInboxStatusById(2, "processing");

И получаю это исключение:

2020-02-10 22:21:57.486 DEBUG 7 --- [main] o.s.orm.jpa.JpaTransactionManager        : Creating new transaction with name [org.springframework.data.jpa.repository.support.SimpleJpaRepository.setInboxStatusById]: PROPAGATION_REQUIRED,ISOLATION_DEFAULT
2020-02-10 22:21:57.486 DEBUG 7 --- [main] o.s.orm.jpa.JpaTransactionManager        : Opened new EntityManager [SessionImpl(1663686815<open>)] for JPA transaction
2020-02-10 22:21:57.486 DEBUG 7 --- [main] o.h.e.t.internal.TransactionImpl         : On TransactionImpl creation, JpaCompliance#isJpaTransactionComplianceEnabled == false
2020-02-10 22:21:57.486 DEBUG 7 --- [main] o.h.e.t.internal.TransactionImpl         : begin
2020-02-10 22:21:57.486 DEBUG 7 --- [main] org.postgresql.jdbc.PgConnection         :   setAutoCommit = false
2020-02-10 22:21:57.486 DEBUG 7 --- [main] o.s.orm.jpa.JpaTransactionManager        : Exposing JPA transaction as JDBC [org.springframework.orm.jpa.vendor.HibernateJpaDialect$HibernateConnectionHandle@10fc01e0]
2020-02-10 22:21:57.487 DEBUG 7 --- [main] org.hibernate.SQL                        : update inbox_inbox i set i.status = ? where i.id = ?
2020-02-10 22:21:57.487 DEBUG 7 --- [main] o.h.engine.jdbc.spi.SqlExceptionHelper   : could not execute statement [n/a]

org.postgresql.util.PSQLException: ERROR: column "i" of relation "inbox_inbox" does not exist
  Position: 26
    at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2497) ~[postgresql-42.2.8.jar!/:42.2.8]
    at .....

Зачем это получать? Я также искал решение на этом сайте. Но, похоже, это новая тема. Так что просить помощи. Заранее спасибо.

1 Ответ

2 голосов
/ 11 февраля 2020

Использование псевдонимов в запросе на обновление запрещено. Пожалуйста, используйте следующее:

@Modifying
@Transactional
@Query(value = "update inbox_inbox set status = ?2 where id = ?1", nativeQuery = true)
int setInboxStatusById(int id, String status);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...