gpt4 book ai didi

java - jcr 查询结构

转载 作者:行者123 更新时间:2023-11-29 03:49:44 25 4
gpt4 key购买 nike

我正在构建一个 jcr 查询并从存储库接收数据。这是我的代码:

    String queryString = "SELECT * FROM public:hours";

try {
// get session
Session session = requestContext.getSession();

// create query from queryString constructed
Query q = session.getWorkspace().getQueryManager().createQuery(queryString, Query.JCR_SQL2);

// execute query and retrieve result
QueryResult result = q.execute();


// debug line
log.error("query is", q.getStatement());
....

但这并不能执行成功。它给我一个错误

Repositorty Failed: 
[INFO] [talledLocalContainer] javax.jcr.query.InvalidQueryException: Query:
[INFO] [talledLocalContainer] SELECT * FROM public:(*)hours; expected: <end>

在 jcr-shell 中,如果我输入 query sql "select * from public:hours" 就会工作,并且会给我正确的结果。
我搜索了很多引用资料,但几乎每个例子都和我的一样。所以我不确定问题出在哪里。任何有这方面经验的人请帮忙。

最佳答案

如果您使用的是 JCR-SQL2 查询语言,那么您应该将选择器名称用方括号括起来:

SELECT * FROM [public:hours]

有关详细信息,请参阅 JSR-283 的第 6.7.4 节(又名 JCR 2.0)规范,也可用 online .请注意,如果名称是有效的 SQL92 标识符,则不需要方括号引号字符。包含 namespace 前缀的节点类型名称始终需要用引号引起来,因为 SQL92 标识符中不允许使用“:”字符。

当然,这假定您有一个名为“public:hours”的节点类型,其中“public”是命名空间前缀。

关于java - jcr 查询结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9368817/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com