当前位置: 首页 > 知识库问答 >
问题:

Spring Pageable不翻译@Column name

齐凯康
2023-03-14

我有实体对象:

@Entity(name = "table")
public class SomeEntity {

    @Id
    @Column(name = "id_column_name")
    public final BigDecimal entityId;

    @Column(name = "table_column_name")
    public final String entityFieldName;

}
CREATE OR REPLACE FORCE EDITIONABLE VIEW "V_TABLE" ("ID_COLUMN_NAME", "TABLE_COLUMN_NAME", "SOME_OTHER_COLUMN") AS ... (some SQL magic) 
@RepositoryRestResource
interface SomeEntityRepository extends PagingAndSortingRepository<SomeEntity, BigDecimal> {

    @Query(value = "select id_column_name, table_column_name FROM V_TABLE where some_other_column = ?#{#parameter} order by ?#{#pageable}",
        countQuery = "SELECT count(*) from V_TABLE v where  some_other_column = ?#{#parameter}",
        nativeQuery = true)
    Page<SomeEntity> findBySomeParameter(@Param("parameter") long parameter, Pageable pageable);
} 

但当我添加排序信息时却不起作用:http://localhost:8080/someEntity/search/findbysomeParameter?parameter=25&page=0&size=20&sort=entityfieldname,asc将引发以下异常(我使用的是Oracle数据库):

Caused by: java.sql.SQLSyntaxErrorException: ORA-00904: "ENTITYFIELDNAME": invalid identifier

排序字段似乎没有用@column(name)翻译,而是内联到SQL查询中。

是否有任何方法使可分页排序翻译,使它将不使用字段名,而使用列名?

共有1个答案

沈思博
2023-03-14

这篇文章阐明了这个问题。请参阅第3.1节。

显然,本机查询不支持动态排序。实际上,如果您将findBySomeParameter方法更改为sort而不是pageable,您将得到org.springframework.data.jpa.repository.query.invalidJPAQueryMethodException:不能使用带有动态排序的本机查询

使用pageable您不会得到异常,分页实际上似乎工作得很好,但是动态排序并不会像您发现的那样替换列名。在我看来,唯一的解决方案是使用JPQL而不是本机查询,只要您需要进行的查询是您提供的查询,这就不是问题。但是,为了使用JPQL,您需要将视图映射到SomeEntityView类。

编辑我以为这个问题没有记录在案,但它实际上在这里的官方文件

Spring Data JPA目前不支持本机查询的动态排序,因为它必须操作声明的实际查询,而对于本机SQL它不能可靠地做到这一点。但是,您可以通过自己指定计数查询来使用本机查询进行分页,如下例所示:

 类似资料:
  • 我试图使用gettext翻译我的PHP项目,但它不起作用。PHP输出gettext字符串名称,而不是实际的翻译。. po文件在POEditor中编译。 设置区域设置: PO文件:(在locale/en/LC_MESSAGES/filename.PO中) 在PHP中回声: 是的,我尝试了从stackoverflow到Google的一切,用了3个多小时。我已经在PHP中安装了gettext,还尝试重新

  • 您可使用 Google Translate™ 应用程式翻译词组: 按下侧边电源按钮打开应用程式菜单,找到并轻触Translate(翻译)。 您将看到翻译源语言与目标语言这两种语言。您可通过轻触某一语言的名称来更改语言。 轻触“麦克风”图标并说出您想翻译的词组。 译文将显示在屏幕上。

  • 本文向大家介绍SVG 翻译,包括了SVG 翻译的使用技巧和注意事项,需要的朋友参考一下 示例 将矩形向右移动10个单位,向下移动20个单位: 将其水平移动0个单位,向上移动20个单位: 将其向左移动10个单位,垂直移动0个单位:            

  • 在学习计算机科学概念时,学生不必在学习英语的同时费劲。 如果您以英语以外的其他语言为母语,那么我们很感谢您为世界上95%的母语不是英语的人所提供的帮助。 Translatewiki Blockly和Blockly游戏的翻译均由Translatewiki处理。 注册成为translatewiki.net的翻译。 做一些测试翻译以获得翻译许可(在右上角选择一种语言)。 简要阅读Blockly的翻译风格

  • 问题内容: 我有Yii2高级模板,我想为前端视图设置翻译,这是我所做的: 然后我加在 和 我在视图中使用它为: 但翻译无效,显示为 问题答案: 您只需按照以下步骤操作…… 步骤1: 在目录中,创建文件夹。 步骤2:在目录内创建文件,内容如下: 注意: 确保将所有必需的语言添加到“语言”数组中。在上面的示例中,我为Generate Yii2 Framework多语言添加了英语和俄语。 步骤3:在文件

  • 你可以在应用程序的启动方法中向本地化文本注册表(local text registry)添加翻译。 这些翻译可来源自数据库表、xml 文件、嵌入的资源等。 void Application_Start() { // ... var registry = Dependency.Resolve<ILocalTextRegistry>(); registry.Add("es",