首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jcr查询构造

jcr查询构造
EN

Stack Overflow用户
提问于 2012-02-21 05:40:18
回答 1查看 1.9K关注 0票数 1

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

代码语言:javascript
复制
    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());
....

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

代码语言:javascript
复制
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",它就可以工作,并会给出正确的结果。

我搜索了很多参考文献,但几乎每个例子都和我的一样。所以我不确定问题出在哪里。任何有这方面经验的人,请帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-02-21 07:01:57

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

代码语言:javascript
复制
SELECT * FROM [public:hours]

有关详细信息,请参阅也可从online获得的JSR-283 (也称为JCR2.0)规范的第6.7.4节。请注意,如果名称是有效的SQL92标识符,则不需要方括号引号字符。包含命名空间前缀的节点类型名称始终需要加引号,因为SQL92标识符中不允许使用':‘字符。

当然,这里假设您有一个名为“public: the”的节点类型,其中"public“是名称空间前缀。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9368817

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档