使用此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
命名参数,我在地图中有以下内容:
paramMap.put("FILE_PATH", "%PATHNAME%");
我不知道为什么会这样。为了让事情更容易混淆(或者它可能会帮助所有人),如果我在文件路径中使用数字,例如paramMap.put("FILE_PATH", "%23%");
它就可以正常工作。
参数映射与查询一起传递到DAO.read()方法。 Hibernate处理剩下的事情。像这样:
fileStatusDao.read(query, parameterMap);
提前感谢您的帮助。
答案 0 :(得分:0)
问题最终是我在一个已经是字符串的属性上使用了STR()函数。