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

使用带注释的本地查询获得正确的流结果?

江英卓
2023-03-14

我目前使用的是hibernate 5.0.7,由于HQL查询的局限性(主要是缺乏顶级或极限能力),我已经到了尝试实现本机SQL查询的地步。由于我们的存储库是通过接口连接成spring bean的,我们目前使用带注释查询和函数查询的组合来获取数据。

我的查询示例如下

@Query(value = "SELECT * FROM some_table where (id = ?1)", nativeQuery = true)
Stream<MyObject> getMyObjectByIds(String userId);

然而;我的实际查询更复杂,使用了GroupBy(函数查询似乎没有的东西)和Top(直接HQL查询似乎没有的东西)

我们数据库中的所有表和项都是映射的实体,当前数据库中的所有数据都是由这些hibernate实体一开始放在那里的。现在,当我运行我的查询时,我实际上得到了一个结果,它看起来非常像我最终得到的数据

{2, 3, 5, Whatever, null}

在我的数据库中,我有一些精确的行值

{2, 3, 5, Whatever, NULL}

但是,当我试图从我的本机查询访问我的函数类型设置为的流对象时,我以错误告终

org.springframework.core.convert.ConversionFailedException: Failed to convert from type [java.lang.Object[]] to type [com.myorg.models.MyObject] for value '{2, 3, 5, Whatever, null}'; nested exception is org.springframework.core.convert.ConverterNotFoundException: No converter found capable of converting from type [java.lang.Integer] to type [com.myorg.models.MyObject]

现在,从我所查找的内容来看,人们似乎认为有一个SqlResultSetMapping映射在某个地方不存在,如果我查看我的实体,确实没有这样的映射

@Entity
@NamedEntityGraph(
    name = "MyObject.withChildren",
    attributeNodes = @NamedAttributeNode(value = "objectChildren")
)
@Getter
@Setter
@Table(name = "object_table", schema = "my_table")
public class MyObject implements Serializable {
@SqlResultSetMapping(
    name = "ObjectMapping",
    entities = {
        @EntityResult(
            entityClass = MyObject.class,
            fields = {
                @FieldResult(name = "id", column = "id"),
                @FieldResult(name = "childId", column = "child_id"),
                @FieldResult(name = "someNumber", column = "some_numbur"),
                @FieldResult(name = "someString", column = "some_string"),
                @FieldResult(name = "someNullableType", column = "null_type_column")
            }
        )
    }
)

并停留在我的实体类上,但我真的不知道如何/为什么/这是否必要,更糟糕的是,它甚至没有工作。尽管这是对我的代码/问题的一个相当模糊的描述,但我是否遗漏了一些简单的东西,或者有人知道我可能做错了什么吗?

我感谢所有人愿意提供的帮助!

共有1个答案

盖锐进
2023-03-14

最后,通过将@namednativeQuery附加到实体对象本身,我成功地实现了这一点

@NamedNativeQuery(
name = "MyEntity.complexSqlQuery",
query = "SELECT TOP 10 * FROM my_table WHERE (my_table.id = ?1)",
resultClass = MyEntity.class

然后加上

@Query(nativeQuery = true)
List<MyEntity> complexSqlQuery(String whatever);

到我的界面样式存储库。我不知道这是否理想,因为它似乎将大量查询转储到实体本身并不完全是最佳实践,我真的希望可以在存储库中已经存在的查询上抛出一些带注释的标记(在我的例子中,resultClass似乎正是@query注释所需要的支持),但似乎不存在这样的选项。

尽管如此,我还是解决了这个问题,只是不一定是以我喜欢的方式。如果有人对我可能错过的东西有一些洞察力,我会非常开放地倾听,否则这就是我在那之前提出的解决方案。

 类似资料:
  • 我对Spring中的原生查询有一个问题。我在param value中使用了带有参数nativequery=true注释@query和SQL查询。 而在RezerWacjamanager.java中: 问题是什么时候调用方法RezerWacjadao.getDoStepnosCnatypy(dataOd,dataDo)并执行此查询。我得到一个错误错误: DoStepNosCtypyListdTo.j

  • 我正在尝试创建一个查询并根据自定义权重计算对其进行排序。 我需要一些帮助作为解决方案我来确实工作但性能是不是在那里我想它是 我拥有的是一个媒体对象。它有相关的评论、喜欢和命令。 以下查询目前有效,但完全是一团乱麻: 如您所见,我正在单独注释我将使用的所有参数,然后对查询集中的每个项目进行愚蠢的遍历,这是非常次优的。 我尝试做的一件事是: 但是注释中的类似操作是不可能的(尝试了一些有和没有Sum()

  • 问题内容: 我有问题,请查看我的数据库: 我想收到这样的信息(按投票顺序,从最高到最低): 您能帮我写正确的SQL查询吗? 问题答案:

  • 我正在开发一个应用程序,使用: Java 1.7 我想对一些字符串属性使用PostgreSQL文本数据类型。据我所知,在JPA中,要使用PostgreSQL中的文本,这应该是正确的注释: 当我像这样注释我的实体时,我遇到的错误如下所示:http://www.shredzone.de/cilla/page/299/string-lobs-on-postgresql-with-hibernate-36

  • 不确定我是不是漏掉了什么。 如有任何建议,将不胜感激。

  • 以下是我的疑问.... 我没有结果。 另外,我正在使用这个插件来生成请求正文。 我的查询如下所示.. null 感谢您到目前为止的阅读,如果有人能帮助我找出如何使这一工作,我将非常感谢。