jcr查询构造

时间:2012-02-20 21:40:18

标签: java sql repository jcr jcr-sql2

我正在构建一个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"并且会给我正确的结果,它会起作用。
我搜索了许多参考文献,但几乎每个例子都与我的相同。所以我不确定问题出在哪里。 任何人都有这方面的经验请帮助。

1 个答案:

答案 0 :(得分:4)

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

SELECT * FROM [public:hours]

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

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