Java 在PostgreSQL中不使用HQL查询

Java 在PostgreSQL中不使用HQL查询,java,hibernate,hql,Java,Hibernate,Hql,我正在使用Java 9、Hibernate 5、PostgreSQL 10,并且我一直在尝试对数据库执行一些HQL查询 此方法适用于: public List<MP3> getAll(String name) { query = session.createQuery( "from " + name); List mp3 = query.list(); return mp3; } 我的简历如下: 08:31:54.292 [main] INFO org.h

我正在使用Java 9、Hibernate 5、PostgreSQL 10,并且我一直在尝试对数据库执行一些HQL查询

此方法适用于:

public List<MP3> getAll(String name) {
    query = session.createQuery( "from " + name);
    List mp3 = query.list();
    return mp3;
}
我的简历如下:

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]

请帮助我解决此问题。

@Transactional
添加到方法中:

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

第一个查询是一个
SELECT
,它不需要事务,但第二个查询是一个
DELETE
,它确实需要一个事务。我尝试过,但没有成功。public void deleteByName(String name){transaction=session.beginTransaction();String hql=“DELETE MP3 where name=:name”;query=session.createQuery(hql);query.setParameter(“name”,name);query.executeUpdate();}提交在哪里?什么意思不起作用?您确定传递的参数正确吗?如果你没有遇到异常,什么也没发生,这就是最可能的原因。干杯,快乐编码。。。不要忘了接受答案作为解决方案,如果可能的话,进行投票。上面没有说这是在JEE环境中执行的
@Transactional
public void deleteByName(String name) {
    String hql = "DELETE MP3  where name = :name";
    query = session.createQuery(hql);
    query.setParameter("name",name);
    query.executeUpdate();
}