GAE 中的查詢過濾:解決不一致的結果和計數器差異
考慮以下場景:兩個記錄插入到資料儲存中,其中一條帶有一個名字是“Joe Citizen”,另一個名字是“Andrew W.”。但是,當執行後續查詢來檢索名為“Andrew W”的記錄時,它會意外返回“Joe Citizen”,這表示查詢過濾器無法正常運作。此外,計數器顯示 2,表示存在兩筆記錄,而實際上預期只有一筆記錄。需要對此問題進行調查,以修正查詢過濾並解決不一致問題。
了解查詢過濾
此問題源自於初始查詢建構中的疏忽。在 Go 的 Datastore API 中,Query.Filter() 方法傳回一個應用了指定過濾器的新查詢物件。它不會修改原始查詢物件。因此,將傳回的查詢指派給新變數至關重要:
// Incorrect approach that does not apply the filter q := datastore.NewQuery("employee") q.Filter("Name =", "Andrew W") // Correct approach that assigns the new query with the filter applied q = datastore.NewQuery("employee").Filter("Name =", "Andrew W")
解決最終一致性
GAE 資料儲存遵循最終一致性,這意味著資料更新可能不會立即對後續查詢可見。為了解決這個問題,請在查詢執行的程式碼中引入短暫的延遲,以便有足夠的時間來傳播資料:
time.Sleep(time.Second) var e2 Employee q := datastore.NewQuery("employee").Filter("Name=", "Andrew W")
可選增強
對於如果結果高度一致,請在建立金鑰時考慮使用祖先金鑰並使用祖先查詢。祖先鍵確保同一實體組內的操作得到一致的處理,而不管最終的一致性考慮因素:
key := datastore.NewKey(c, "employee", "", 0, ancestorKey)
最終,透過解決這些問題,查詢過濾將按預期運行,返回預期的記錄並準確反映資料儲存中的計數器值。
以上是為什麼我的 Google App Engine 資料儲存區查詢傳回不一致的結果並顯示不正確的計數器值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!