使用Go 在Google App Engine 資料儲存區中按ID 擷取實體
使用Google App Engine 資料儲存區時,執行高效查詢至關重要檢索特定實體。其中一個查詢是「IN Array」查詢,您可以在其中根據 ID 陣列過濾實體。
執行「IN Array」查詢的挑戰
In Go,資料儲存 API 不直接支援「IN」陣列過濾器。嘗試使用 datastore.NewQuery("Category").Filter("Id IN", ids) 將會導致錯誤。
替代方法
While "IN 「過濾器不能直接使用,有其他方法可以達到相同的結果:
1.迭代查詢
您可以對數組中的每個ID 執行單獨的查詢。例如:
<code class="go">ids := []int64{1,2,3,4} for _, id := range ids { q := datastore.NewQuery("Category").Filter("Id =", id) }</code>
2。範圍查詢
如果ID在連續範圍內,則可以使用範圍查詢而不是「IN」過濾器。例如:
<code class="go">ids := []int64{1,2,3,4} q := datastore.NewQuery("Category").Filter("Id>=", 1).Filter("Id<=", 4)</code>
3。 GetMulti 函數
如果您要篩選的屬性是實體鍵本身,則可以使用 datastore.GetMulti() 函數擷取由鍵數組指定的實體清單。例如:
<code class="go">keys := make([]*datastore.Key, len(ids)) for i, id := range ids { keys[i] = datastore.NewKey(c, "Category", "", id, nil) } categories := make([]Category, len(keys)) err := datastore.GetMulti(c, keys, categories)</code>
注意:
對於大型數組,迭代查詢可能效率較低。範圍查詢適用於連續範圍,但不支援間隙。 GetMulti 針對透過鍵檢索實體進行了最佳化。
以上是如何使用 Go 在 Google App Engine 資料儲存中按 ID 檢索實體:「IN Array」查詢的替代方案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!