首頁  >  文章  >  後端開發  >  如何使用 Go 在 Google App Engine 資料儲存中按 ID 檢索實體:「IN Array」查詢的替代方案?

如何使用 Go 在 Google App Engine 資料儲存中按 ID 檢索實體:「IN Array」查詢的替代方案?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-10-26 12:50:02359瀏覽

How to Retrieve Entities by IDs in Google App Engine Datastore with Go: Alternatives to

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

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