使用此 HQL 查询:
SELECT DISTINCT fs FROM FileStatus fs WHERE UPPER(STR(fs.filePath)) LIKE :FILE_PATH
我得到:
javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not execute query
at org.hibernate.ejb.AbstractEntityManagerImpl.throwPersistenceException(AbstractEntityManagerImpl.java:637)
at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:74)
还有我的FILE_PATH
命名参数,我在 map 中有以下内容:
paramMap.put("FILE_PATH", "%PATHNAME%");
我不知道为什么会发生这种情况。为了让事情变得更加困惑(或者也许它会对每个人有所帮助),如果我在文件路径中使用数字,例如 paramMap.put("FILE_PATH", "%23%");
它工作得很好。
参数映射与查询一起传递到 DAO.read() 方法中。 Hibernate 会处理剩下的事情。像这样的事情:
fileStatusDao.read(query, parameterMap);
预先感谢您的帮助。
最佳答案
问题最终是我在已经是字符串的属性上使用 STR() 函数。
关于java - HQL 中 STR() 函数的错误使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3533932/