java - HQL 中 STR() 函数的错误使用

标签 java hibernate hql

使用此 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/

相关文章:

java - 如何检查主类java中的命令参数

java - 消费者应用程序中的 JMS ConnectionFactory NullPointerException

java - 交易未成功开始

java - 请求处理失败

hibernate - 如何在 HQL Hibernate 中将列的大小写更改为 Upper

java - Spring 启动: getting this error - Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured

java - 读取src中相对静态文件

java - MappingException hibernate 映射列

java - 在 Hibernate 中设置连接

java - Hibernate删除对象而不删除相关对象