Firestore는 "==" 및 "!="와 같은 연산자를 사용하여 데이터를 쿼리하는 강력한 방법을 제공합니다. 동적 필터를 처리할 때 사용자 입력에 따라 where 절을 조건부로 적용해야 합니다.
색상, 저자, 카테고리와 같은 속성을 가진 책 목록이 있는 시나리오를 생각해 보세요. 사용자가 다양한 색상 및 카테고리 선택을 기반으로 책을 필터링할 수 있도록 허용하려고 합니다. Firestore where 절을 사용하여 이를 구현하는 방법을 살펴보겠습니다.
<code class="javascript">// Assume you have dynamic filters captured as arrays const colors = ["Red", "Blue"]; const categories = ["Adventure", "Detective"]; // Create the base query var query = firebase.firestore().collection("book"); // Loop through the dynamic filters and add where clauses if (colors.length > 0) { query = query.where("color", "in", colors); } if (categories.length > 0) { query = query.where("category", "in", categories); } // Add ordering logic query = query.orderBy("date"); // Execute the query query.get().then((querySnapshot) => {...});</code>
위 예에서는 먼저 기본 쿼리를 설정합니다. 그런 다음 사용자가 선택한 필터가 있는지에 따라 조건부로 where 절을 추가합니다. 마지막으로 순서를 적용하고 쿼리를 실행합니다.
이 접근 방식을 사용하면 여러 where 절을 동적으로 적용할 수 있으므로 변화하는 사용자 기본 설정에 유연하고 적응할 수 있습니다. 불필요한 쿼리를 피하기 위해 빈 필터를 처리해야 한다는 점을 명심하세요.
위 내용은 Firestore에서 여러 조건부 Where 절을 어떻게 구현할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!