首頁 >後端開發 >Golang >為什麼我的 Google App Engine 資料儲存區查詢傳回不一致的結果並顯示不正確的計數器值?

為什麼我的 Google App Engine 資料儲存區查詢傳回不一致的結果並顯示不正確的計數器值?

Barbara Streisand
Barbara Streisand原創
2024-12-04 05:18:12509瀏覽

Why is my Google App Engine datastore query returning inconsistent results and displaying incorrect counter values?

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn