Не работают HQL-запросы в PostgreSQL - PullRequest
0 голосов
/ 14 мая 2018

Я использую Java 9, Hibernate 5, PostgreSQL 10. Я пытался выполнить несколько запросов HQL к базе данных.

Этот метод работает:

public List<MP3> getAll(String name) {
    query = session.createQuery( "from " + name);
    List mp3 = query.list();
    return mp3;
}

Но этот методне работает:

public void deleteByName(String name) {
        String hql = "DELETE MP3  where name = :name";
        query = session.createQuery(hql);
        query.setParameter("name",name);
        query.executeUpdate();
    }

Мой StackTrace выглядит следующим образом:

08:31:54.292 [main] INFO  org.hibernate.orm.connections.access - HHH10001501: Connection obtained from JdbcConnectionAccess [org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess@401317a0] for (non-JTA) DDL execution was not in auto-commit mode; the Connection 'local transaction' will be committed and the Connection will be set into auto-commit mode.
08:31:54.308 [main] INFO  org.hibernate.hql.internal.QueryTranslatorFactoryInitiator - HHH000397: Using ASTQueryTranslatorFactory
Hibernate: 
    delete 
    from
        MP3 
    where
        name=?
08:31:54.386 [main] INFO  org.hibernate.orm.connections.pooling - HHH10001008: Cleaning up connection pool [jdbc:postgresql://localhost:5432/postgres]

Пожалуйста, помогите мне в решении проблемы.

1 Ответ

0 голосов
/ 14 мая 2018

Добавьте @Transactional к методу:

@Transactional
public void deleteByName(String name) {
    String hql = "DELETE MP3  where name = :name";
    query = session.createQuery(hql);
    query.setParameter("name",name);
    query.executeUpdate();
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...