- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
从Spring Boot的1.5.4
升级到2.1.0 LTS
之后
我遇到了一些关于特定存储库方法的问题。
我检查了 SO 和 JIRA 上提及 @Query
和 @ResultsSetMapping
的各种问题,并相应地应用了这些更改,但我仍然面临同样的问题。
例如这里:
存储库
@CrossOrigin
@RepositoryRestResource(path = "/iCreateChange")
public interface ICreateChangeRepository extends JpaRepository<ICreateChange, Long> {
List<ChangeTask> listStartedChangesByInitiator(
@Param("initiator")
@RequestParam
@ApiParam(name = "initiator", value = "initiator")
String initiator);
List<ChangeTask> listDataValuesAndStatusByChangeId(
@Param("changeId")
@RequestParam
@ApiParam(name = "changeId", value = "changeId")
Long changeId);
}
实体
@SqlResultSetMappings({
@SqlResultSetMapping(
name = "StartedChangeMapping",
classes = @ConstructorResult(
targetClass = ChangeTask.class,
columns = {
@ColumnResult(name = "id", type = Long.class),
@ColumnResult(name = "status", type = String.class),
@ColumnResult(name = "data_values", type = String.class)
}
)
),
@SqlResultSetMapping(
name = "ActiveTaskChangeMapping",
classes = @ConstructorResult(
targetClass = ChangeTask.class,
columns = {
@ColumnResult(name = "id", type = Long.class),
@ColumnResult(name = "status", type = String.class),
@ColumnResult(name = "data_values", type = String.class)
}
)
)
})
@NamedNativeQueries({
@NamedNativeQuery(
name = "ICreateChange.listStartedChangesByInitiator",
query =
"SELECT id as id, status as status, data_values as data_values "
+ "FROM icreate_change "
+ "WHERE initiator = :initiator "
+ "AND workflow_process_id = 0",
resultSetMapping = "StartedChangeMapping"
),
@NamedNativeQuery(
name = "ICreateChange.listDataValuesAndStatusByChangeId",
query =
"SELECT id as id, status as status, data_values as data_values "
+ "FROM icreate_change "
+ "WHERE id = :changeId",
resultSetMapping = "ActiveTaskChangeMapping"
)
})
@Data
@Entity
@Table(name = "icreate_change")
public class ICreateChange {
public ICreateChange() {}
....
我错过了什么吗?
堆栈跟踪
org.hibernate.HibernateException: Got different size of tuples and aliases
at org.hibernate.jpa.spi.NativeQueryTupleTransformer$NativeTupleImpl.<init>(NativeQueryTupleTransformer.java:68) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.jpa.spi.NativeQueryTupleTransformer.transformTuple(NativeQueryTupleTransformer.java:28) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.hql.internal.HolderInstantiator.instantiate(HolderInstantiator.java:85) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.loader.custom.CustomLoader.getResultList(CustomLoader.java:433) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2506) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.loader.Loader.list(Loader.java:2501) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.loader.custom.CustomLoader.list(CustomLoader.java:338) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.internal.SessionImpl.listCustomQuery(SessionImpl.java:2223) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.internal.AbstractSharedSessionContract.list(AbstractSharedSessionContract.java:1053) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.query.internal.NativeQueryImpl.doList(NativeQueryImpl.java:170) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.query.internal.AbstractProducedQuery.list(AbstractProducedQuery.java:1505) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
at org.hibernate.query.Query.getResultList(Query.java:135) ~[hibernate-core-5.3.7.Final.jar:5.3.7.Final]
调试
调试 NativeTupleImpl
的实现显示别名和元组在那里,但是存在嵌套问题。有一个包含所有值的元组对象,但有 3 个别名,它们没有嵌套并且作为三个实体。这是造成不匹配的原因
引用:
https://jira.spring.io/si/jira.issueviews:issue-html/DATAJPA-1280/DATAJPA-1280.html
"Got different size of tuples and aliases" exception after Spring Boot 2.0.0.RELEASE migration
最佳答案
问题与 Hibernate 默认情况下如何将其元组实体映射到对象或对象列表有关。
在这种情况下,它期望三个元组映射到 POJO 中的各个列。
这是让它工作的代码(注意省略了@ConstructorResult
)
@SqlResultSetMapping(
name = "TaskChangeMapping",
columns = {
@ColumnResult(name = "id", type = Long.class),
@ColumnResult(name = "status", type = String.class),
@ColumnResult(name = "data_values", type = String.class)
})
关于java - Spring 数据 2.1.1 org.hibernate.HibernateException : Got different size of tuples and aliases?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53169393/
我有一个包含文件名 和文件路径 的元组列表。我想找到重复的 filename(但 filepath 可能不同),即文件名相同但 filepath 可能不同的元组。 元组列表示例: file_info
我有一个像这样定义的变量 auto drum = std::make_tuple ( std::make_tuple ( 0.3f , Ex
我有一个包含几个字段的自定义结构,我想在快速 switch 语句中对其进行模式匹配,这样我就可以通过将其中一个字段与另一个字段进行比较来自定义匹配正则表达式。 例如鉴于这种结构: struct MyS
我有一种动态元组结构: template //Should only be tuples class DynamicTuple { vector data; //All data is st
这个问题在这里已经有了答案: What and When to use Tuple? [duplicate] (5 个答案) 关闭 8 年前。 我正在查看 Tuple 的在线示例,但我没有看到任何理
在我的项目中我有很多坐标要处理,在二维情况下我发现(cons x y)的构造比(list x y)快和 (vector x y)。 但是,我不知道如何将 cons 扩展到 3D 或更进一步,因为我没有
我有以下 Scala 代码: def f(x: Int, y: Int): Option[String] = x*y match { case 0 => None case n =>
我的直觉告诉我,在一般情况下,只有宏或复杂类型的体操才能解决这个问题。 Shapeless 或 Scalaz 可以在这里帮助我吗?这是 N=2 问题的具体实例,但我正在寻找的解决方案适用于所有合理的
为什么这段 Scala 代码是这样的: class Test { def foo: (Int, String) = { (123, "123") } def bar: Unit
我是 python 和 pygame 的新手,我正在尝试学习向量和类的基础知识,但在这个过程中我搞砸了,而且我在理解和修复标题中的错误消息方面苦苦挣扎。 这是我的 Vector 类的代码: impor
我正在编写一个程序来打开和读取一个 txt 文件,并在每一行中循环。将第 2 列和第 4 列中的值相乘并将其分配给第 5 列。 A 500.00 A 84.15 ? B 648.80 B 77.61
我知道还有其他几个问题提出了完全相同的问题,但是当我运行时: 导入命令 从 pyDes 导入 * def encrypt(data, password,): k = des(password,
我有一个元组列表,内容如下: >>>myList [(), (), ('',), ('c', 'e'), ('ca', 'ea'), ('d',), ('do',), ('dog', 'ear', '
给定一个 boost::tuple 和 std::tuple,你如何在它们之间进行转换? 也就是说,您将如何实现以下两个功能? template boost::tuple asBoostTuple(
我无法初始化 std::tuple来自 std::tuple 的逐元素元素兼容类型。为什么它不像 boost::tuple 那样工作? #include #include template st
我是 Storm 的新手并且我正在尝试找出如何编写一个 bolt 测试来测试子类 BaseRichBolt 中的 execute(Tuple tuple) 方法。 问题是 Tuple 似乎是不可变的,
如果我有如下元组列表: [('a', 'b'), ('c', 'd'), ('a', 'b'), ('b', 'a')] 我想删除重复的元组(在内容和内部项目顺序方面重复)以便输出为: [('a',
我编写了一个简单的脚本来模拟基于每用户平均收入 (ARPU)、利润率和客户保持客户的年数 (ltvYears) 的客户生命周期值(value) (LTV)。下面是我的脚本。它在“ltvYears =
以下是我的代码,它是一组元组:。输出:设置([(‘A’,20160129,36.44),(‘A’,20160104,41.06),(‘A’,20160201,37.37)])。如何将另一个元组(‘A’
我用以下代码编写了一个程序: import pandas as pd import numpy as np from typing import Tuple def split_data(self,
我是一名优秀的程序员,十分优秀!