【发布时间】:2019-05-22 20:00:34
【问题描述】:
我无法使用内部 id 在 JPQL 中检索此文档
{
"_id" : {
"activity_id" : NumberLong(1),
"id" : NumberLong(629364456)
},
"date" : ISODate("2018-12-22T23:41:22.951Z"),
"sys_date" : ISODate("2018-12-22T23:41:22.951Z"),
"disable_revision" : 0,
"type" : "myMongoEvent",
"title" : "ref title",
"revision" : "0.0",
"freeze" : false,
"user_id" : 0,
"syncdate" : ISODate("2018-12-22T23:41:22.951Z"),
"undelable" : 0,
"username" : ""
}
查询:
Query query = entitymanager.createQuery("SELECT e.title FROM Event e WHERE e.id.id=:id");
query.setParameter("id",2046229248L);
List results = query.getResultList();
如果我查询像 title 这样的纯字符串字段,它会起作用。
如果我使用复合索引的 id 查询则不会(我需要复合索引)。
即使我查询不存在的title,我也会收到错误java.lang.StringIndexOutOfBoundsException: String index out of range: -1..我应该只是得到空结果,为什么会抛出异常?
【问题讨论】:
标签: mongodb jakarta-ee jpql hibernate-ogm