- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想在 HQL 查询中构造一个包含类的列表,但每当我尝试将列表传递给新类时,SQL 生成都会失败,并告诉我 org.postgresql.util.PSQLException: ERROR: syntax error at or near "."
。最终结果应该是一个 Form 对象列表,其中每个 Form 包含一个投票列表。
如果我以 SELECT new com.my.class.Projection(q.id, q.otherId, q.votes)
开始查询,q.votes 将生成为 .
在 SQL 中这会导致错误。但是,如果我将投影的投票列表更改为 int (并将查询更改为 SELECT new com.my.class.Projection(q.id, q.otherId, q.votes.size)
只是为了获取大小,它会告诉我大小是多少。为什么我可以检索投票数,但不能检索列表本身?任何帮助将不胜感激!
将生成的部分 SQL:
Hibernate: select question0_.id as col_0_0_, question0_.other_id as col_1_0_, . as col_2_0_ from public.questions`
源代码:
问题库
interface QuestionRepository : JpaRepository<Question, Long> {
@Query("SELECT new com.my.class.Projection(q.id, q.otherId, q.votes) FROM Question q WHERE q.form = :form")
fun findQuestionSimple(@Param("form") form: Form): List<Projection>
投影
data class Projection(
var id: Long = 0,
var otherId: String
) {
@OneToMany(mappedBy = "question")
var votes: List<VoteProjection>? = listOf()
constructor(id: Long, otherId: String, votes: List<Vote>) : this(id, otherId) {
this.id = id
this.otherId = otherId
this.votes = votes.map { VoteProjection(it.id, if (it.user !== null) VoteGuestProjection(it.user!!.id) else null) }
}
}
data class VoteProjection(
var id: Long = 0,
var user: VoteUserProjection?
)
data class VoteUserProjection(
var id: Long = 0
)
问题类别
@Entity
@Table(name = "questions", schema = "PUBLIC")
class Question {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
var id: Long = 0
@NotNull
var otherId = ""
@ManyToOne
@JsonIgnore
@JoinColumn
var form: Form? = null
@OneToMany(mappedBy = "form")
@JsonIgnoreProperties("form")
var votes: List<Vote> = listOf()
}
投票类别
@Entity
@Table(name = "votes", schema = "PUBLIC")
class Vote {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
var id: Long = 0
@ManyToOne
@JoinColumn
var user: User? = null // Not relevant for this question
}
最佳答案
DTO 投影的主要目的是有效地将元组映射到 DTO 类。我认为它不适用于协会。
现在,为了解决您的特定问题,我会这样做:
@Query("SELECT new com.my.class.Projection(q) FROM Question q WHERE q.form = :form")
Projection
构造函数constructor(q: Question) : this(id, otherId) {
this.id = q.id
this.otherId = q.otherId
this.votes = q.votes.map { VoteProjection(it.id, if (it.user !== null) VoteGuestProjection(it.user!!.id) else null) }
}
这会起作用,尽管我不认为这是最好的方法。看来你想做一些转换,这就是 ResultTransformer 的目的.
关于java - 尝试将列表传递给 hibernate 中的新类时出现错误,org.postgresql.util.PSQLException : ERROR: syntax error at or near "." ,,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60137540/
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!