【问题标题】:jcr query constructjcr 查询构造
【发布时间】:2012-02-20 21:40:18
【问题描述】:

我正在构建一个 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",它就会工作,并且会给我正确的结果。
我搜索了许多参考资料,但几乎每个示例都与我的相同。所以我不确定问题出在哪里。 谁有这方面的经验,请帮忙。

【问题讨论】:

    标签: java sql repository jcr jcr-sql2


    【解决方案1】:

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

    SELECT * FROM [public:hours]
    

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

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

    【讨论】:

    • 嗨@Randall 谢谢你的回答!它消除了错误,但我仍然无法得到任何东西。(注意,我可以使用 query sql "select * from public:hours" 从 shell 获取结果)
      请查看我代码中的最后一行,即 log.error("query is", q.getStatement()); 它给了我一个结果query statement is 没有任何后续。所以我想知道我仍然没有正确构建查询?谢谢
    猜你喜欢
    • 2018-11-24
    • 1970-01-01
    • 2023-03-22
    • 2011-03-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-09-05
    相关资源
    最近更新 更多