我刚开始学习Couchbase
。我正在尝试使用java sdk编写基本查询,但我无法理解如何编写它。以下是查询:
SELECT *
FROM users_with_orders usr
JOIN orders_with_users orders
ON KEYS ARRAY s.order_id FOR s IN usr.shipped_order_history END
这是为了没有数组加入:
LetPath path = select("*,META(usr).id as _ID,META(usr).cas as _CAS).from(bucketName +" usr").join(bucketname +" orders").onKeys("usr.order_id)
我应该如何处理on keys数组的上述查询?
感谢!!!!
答案 0 :(得分:5)
如docs on Querying from the SDK中所述,您可以使用Java SDK中的简单字符串或使用DSL。例如:
// query with a simple string
System.out.println("Simple string query:");
N1qlQuery airlineQuery = N1qlQuery.simple("SELECT `travel-sample`.* FROM `travel-sample` WHERE name=\"United Airlines\" AND type=\"airline\"");
N1qlQueryResult queryResult = bucket.query(airlineQuery);
for (N1qlQueryRow result: queryResult) {
System.out.println(result.value());
}
//query with a parameter using the DSL
System.out.println("Parameterized query using the DSL:");
Statement statement = select(path(i("travel-sample"), "*")).from(i("travel-sample")).where(x("name").eq(x("$airline_param")).and(x("type").eq(s("airline"))));
JsonObject placeholderValues = JsonObject.create().put("airline_param", "United Airlines");
N1qlQuery airlineQueryParameterized = N1qlQuery.parameterized(statement, placeholderValues);
N1qlQueryResult queryResultParameterized = bucket.query(airlineQueryParameterized);
for (N1qlQueryRow row : queryResultParameterized) {
System.out.println(row);
}
(我发布了此示例的a full gist用于导入等。)
有关详细信息,请参阅文档,但您可能希望使用DSL来允许IDE代码完成和Java编译时检查。在开发交互式Web应用程序时,您可能还希望使用参数化语句(为了安全性),甚至可能需要预处理语句(用于性能)。