효율적인 GAE 쿼리 필터링
이 문서에서는 Google App Engine(GAE) 쿼리를 필터링할 때 직면하는 일반적인 문제를 다룹니다. 문제는 필터가 적용되지 않는 것 같아 예상치 못한 검색 결과가 나올 때 발생합니다.
제공된 코드 조각을 고려하세요.
q := datastore.NewQuery("employee") q.Filter("Name =", "Andrew W")
이 예에서 목표는 검색하는 것입니다. 특정 이름 속성 "Andrew W."를 가진 엔터티 그러나 쿼리가 예상대로 작동하지 않습니다. 이 문제를 해결하려면 Query.Filter()가 필터가 적용된 파생 쿼리를 반환한다는 점을 이해하는 것이 중요합니다. 따라서 올바른 접근 방식은 Query.Filter()의 반환 값을 저장하고 사용하는 것입니다.
q := datastore.NewQuery("employee").Filter("Name =", "Andrew W")
또는 간결성을 위해 한 줄로 작성할 수도 있습니다.
q := datastore.NewQuery("employee").Filter("Name =", "Andrew W")
고려해야 할 또 다른 중요한 요소는 GAE 개발 SDK의 데이터 저장소 작업에 영향을 미치는 최종 일관성입니다. 이는 Put() 작업 직후에 실행된 쿼리가 저장된 엔터티를 즉시 반환하지 않을 수 있음을 의미합니다. 이 문제를 해결하기 위해 쿼리를 실행하기 전에 짧은 지연을 도입할 수 있습니다.
time.Sleep(time.Second) var e2 Employee q := datastore.NewQuery("employee").Filter("Name=", "Andrew W") // Rest of the code...
일관적인 결과를 얻으려면 키를 생성할 때 상위 키를 사용하는 것이 좋습니다. 강력하게 일관된 결과가 요구되지 않는 한 상위 키는 필수가 아닙니다. 결과가 약간 지연되는 것이 허용되는 경우 상위 키는 필요하지 않습니다.
상위 키는 의미 체계에만 사용되는 가상 키일 수 있으며 기존 엔터티를 나타낼 필요가 없다는 점을 기억하세요. 동일한 상위 키가 할당된 항목은 항목 그룹을 형성하며 이 그룹의 상위 쿼리는 강력한 일관성을 갖습니다.
위 내용은 내 Google App Engine 쿼리가 올바르게 필터링되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!