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

时间:2017-08-08 17:24:21

标签: java mysql spring hibernate

我目前正在使用hibernate 5.0.7,并且由于HQL查询的限制(主要是缺少TOP或LIMIT能力),我已经到了试图实现本机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 个答案:

答案 0 :(得分:0)

最后,我设法通过将@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注释需要在我的情况下支持),但似乎没有这样的选项存在。

尽管如此,我确实得到了解决,但不一定是我喜欢的方式。 如果有人对我可能错过的内容有所了解,我会非常乐意听到它,否则这是我在此之前提出的解决方案。