From 183ce4dbd63fe35306bc5f5b10f7ddf5166ac0ab Mon Sep 17 00:00:00 2001 From: Morgan Chen Date: Thu, 2 Mar 2023 16:07:27 -0800 Subject: [PATCH] Add OR snippets --- .../google/example/firestore/DocSnippets.java | 88 +++++++++++++++++++ .../example/firestore/kotlin/DocSnippets.kt | 88 +++++++++++++++++++ 2 files changed, 176 insertions(+) diff --git a/firestore/app/src/main/java/com/google/example/firestore/DocSnippets.java b/firestore/app/src/main/java/com/google/example/firestore/DocSnippets.java index 37cf8266a..b57e2bb3b 100644 --- a/firestore/app/src/main/java/com/google/example/firestore/DocSnippets.java +++ b/firestore/app/src/main/java/com/google/example/firestore/DocSnippets.java @@ -1335,4 +1335,92 @@ public void onComplete(@NonNull Task task) { }); // [END count_aggregate_query] } + + public void orQuery() { + CollectionReference collection = db.collection("cities"); + // [START or_queries] + Query query = collection.where(Filter.and( + Filter.greaterThan("name", "L"), + Filter.or( + Filter.equalTo("capital", true), + Filter.greaterThanOrEqualTo("population", 1000000) + ) + )); + // [END or_queries] + } + + public void orQueryDisjunctions() { + CollectionReference collection = db.collection("cities"); + + // [START one_disjunction] + collection.whereEqualTo("a", 1); + // [END one_disjunction] + + // [START two_disjunctions] + collection.where(Filter.or( + Filter.equalTo("a", 1), + Filter.equalTo("b", 2) + )); + // [END two_disjunctions] + + // [START four_disjunctions] + collection.where(Filter.or( + Filter.and( + Filter.equalTo("a", 1), + Filter.equalTo("c", 3) + ), + Filter.and( + Filter.equalTo("a", 1), + Filter.equalTo("d", 4) + ), + Filter.and( + Filter.equalTo("b", 2), + Filter.equalTo("c", 3) + ), + Filter.and( + Filter.equalTo("b", 2), + Filter.equalTo("d", 4) + ) + )); + // [END four_disjunctions] + + // [START four_disjunctions_compact] + collection.where(Filter.and( + Filter.or( + Filter.equalTo("a", 1), + Filter.equalTo("b", 2) + ), + Filter.or( + Filter.equalTo("c", 3), + Filter.equalTo("d", 4) + ) + )); + // [END four_disjunctions_compact] + + // [START 20_disjunctions] + collection.where(Filter.or( + Filter.inArray("a", Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)), + Filter.inArray("b", Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)), + )); + // [END 20_disjunctions] + + // [START 10_disjunctions] + collection.where(Filter.and( + Filter.inArray("a", Arrays.asList(1, 2, 3, 4, 5)), + Filter.or( + Filter.equalTo("b", 2), + Filter.equalTo("c", 3) + ) + )); + // [END 10_disjunctions] + } + + public void illegalDisjunctions() { + // [START 50_disjunctions] + collection.where(Filter.and( + Filter.inArray("a", Arrays.asList(1, 2, 3, 4, 5)), + Filter.inArray("b", Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)), + )); + // [END 50_disjunctions] + } } diff --git a/firestore/app/src/main/java/com/google/example/firestore/kotlin/DocSnippets.kt b/firestore/app/src/main/java/com/google/example/firestore/kotlin/DocSnippets.kt index 1be9d8322..a58c1e215 100644 --- a/firestore/app/src/main/java/com/google/example/firestore/kotlin/DocSnippets.kt +++ b/firestore/app/src/main/java/com/google/example/firestore/kotlin/DocSnippets.kt @@ -1107,4 +1107,92 @@ abstract class DocSnippets(val db: FirebaseFirestore) { } // [END count_aggregate_query] } + + fun orQuery() { + val collection = db.collection("cities") + // [START or_query] + val query = collection.where(Filter.and( + Filter.greaterThan("name", "L"), + Filter.or( + Filter.equalTo("capital", true), + Filter.greaterThanOrEqualTo("population", 1000000) + )) + // [END or_query] + } + + fun orQueryDisjunctions() { + val collection = db.collection("cities") + + // [START one_disjunction] + collection.whereEqualTo("a", 1) + // [END one_disjunction] + + // [START two_disjunctions] + collection.where(Filter.or( + Filter.equalTo("a", 1), + Filter.equalTo("b", 2) + )) + // [END two_disjunctions] + + // [START four_disjunctions] + collection.where(Filter.or( + Filter.and( + Filter.equalTo("a", 1), + Filter.equalTo("c", 3) + ), + Filter.and( + Filter.equalTo("a", 1), + Filter.equalTo("d", 4) + ), + Filter.and( + Filter.equalTo("b", 2), + Filter.equalTo("c", 3) + ), + Filter.and( + Filter.equalTo("b", 2), + Filter.equalTo("d", 4) + ) + )) + // [END four_disjunctions] + + // [START four_disjunctions_compact] + collection.where(Filter.and( + Filter.or( + Filter.equalTo("a", 1), + Filter.equalTo("b", 2) + ), + Filter.or( + Filter.equalTo("c", 3), + Filter.equalTo("d", 4) + ) + )) + // [END four_disjunctions_compact] + + // [START 20_disjunctions] + collection.where(Filter.or( + Filter.inArray("a", [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]), + Filter.inArray("b", [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]), + )) + // [END 20_disjunctions] + + // [START 10_disjunctions] + collection.where(Filter.and( + Filter.inArray("a", [1, 2, 3, 4, 5]), + Filter.or( + Filter.equalTo("b", 2), + Filter.equalTo("c", 3) + ) + )) + // [END 10_disjunctions] + } + + fun illegalDisjunctions() { + val collection = db.collection("cities") + // [START 50_disjunctions] + collection.where(Filter.and( + Filter.inArray("a", [1, 2, 3, 4, 5]), + Filter.inArray("b", [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]), + )); + // [END 50_disjunctions] + } }