5

我正在尝试制定一个公式来选择用户个人资料的用户友好名称。如果其中至少一个不为空且不为空(包含非空白字符),则选择firstname + ' ' + lastname ,否则选择shortname(条件相同),最后,如果shortname为空或空,则选择id,转换为字符串。

@Formula("COALESCE(NULLIF(TRIM(BOTH FROM CONCAT(sp.firstname, ' ', sp.lastname)), ''), TRIM(p.shortname), to_char(p.id, 'FM9999999999999999')) " +
   "FROM socialprofile AS sp " +
   "JOIN profile AS p ON sp.id=p.id")
   public String getUserFriendlyName() {
      return super.getUserFriendlyName();
   }

结果是:

org.hibernate.HibernateException: Unexpected number of trim function operands : 10

但只有 3 个参数:BOTH、FROM 和 CONCAT 的结果。这个问题有什么解决方法吗?DB 是 PostgreSQL 9.1,Hibernate 版本是 4.2.1。以防万一,这是表结构:

Profile
  bigint id
  text shortname

SocialProfile
  bigint id
  text firstname
  text lastname

在 Java 代码 SocialProfile 扩展 Profile 中,它们通过id字段作为一对一相关联。在 PgAdmin SQL 编辑器中,此请求完美运行。

4

2 回答 2

5

我也遇到了这个问题。似乎@Formula委托给Hibernate 的内部“where 模板”解析器,它不期望嵌套在trim(). 这个问题之前被报告为HHH-5970,但他们没有做任何事情。

解决方法很简单:不要trim()@Formula. 取而代之的是使用例如ltrim(rtrim(..))甚至是特定于数据库的正则表达式函数,该函数替换"^\s+|\s+$""",具体取决于所使用的数据库的功能。

PostgreSQL 支持ltrim()and rtrim(),所以这应该为你做:

@Formula("COALESCE(NULLIF(LTRIM(RTRIM(BOTH FROM CONCAT(sp.firstname, ' ', sp.lastname))), '') [...]"
于 2017-06-29T11:10:48.707 回答
0

由于 Hibernate 更改公式的内容以便能够附加到原始查询,我也遇到了公式注释的许多问题。这导致我在这些情况下使用 db 视图,而不是使用不可预测的 Hibernate 公式。

于 2019-10-18T08:44:27.907 回答