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