首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不使用PostgreSQL中的HQL查询

不使用PostgreSQL中的HQL查询
EN

Stack Overflow用户
提问于 2018-05-14 05:41:44
回答 1查看 321关注 0票数 2

我正在使用Java9、Hibernate 5、PostgreSQL 10,我一直在尝试用数据库进行一些HQL查询。

这种方法有效:

代码语言:javascript
复制
public List<MP3> getAll(String name) {
    query = session.createQuery( "from " + name);
    List mp3 = query.list();
    return mp3;
}

但是,这种方法不起作用:

代码语言:javascript
复制
public void deleteByName(String name) {
        String hql = "DELETE MP3  where name = :name";
        query = session.createQuery(hql);
        query.setParameter("name",name);
        query.executeUpdate();
    }

我的StackTrace如下:

代码语言:javascript
复制
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]

请帮我解决这个问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-14 07:51:50

@Transactional添加到方法中:

代码语言:javascript
复制
@Transactional
public void deleteByName(String name) {
    String hql = "DELETE MP3  where name = :name";
    query = session.createQuery(hql);
    query.setParameter("name",name);
    query.executeUpdate();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50323676

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档