我正在運行一個與datastore. 我有一個結構,可以轉換為 上的數據庫模型datastore,并且我在結構中添加了一個新字段,將其稱為NewField(類型string)該結構的現有實例(數據庫中的“行”)NewField當然缺少這種情況,這是意料之中的。我正在尋找創建一個查詢,該查詢將返回所有NewField缺少此內容的實例(現有實例)。這是我嘗試過的:q := datastore.NewQuery("MyModel")q = q.Filter("NewField =", "")但是,這似乎不起作用。關于如何實現這一目標的任何想法?
1 回答

紫衣仙女
TA貢獻1839條經驗 獲得超15個贊
壞消息是你不能。
GAE Datastore 上的每個查詢都對索引進行操作。由于您剛剛添加了新屬性,因此沒有該屬性的現有實體將不會出現在任何索引中(包括該屬性)。您需要的是遍歷沒有索引記錄的實體,但這是不可能的。
最好的辦法是查詢所有實體,并在 Go 代碼中手動進行過濾/更新,其中NewField
字段的值為零。重新保存現有實體后,新屬性將被編入索引,您將來可以按該屬性搜索/過濾。
如果您的實體有任何機會存儲創建時間或上次更新時間(在屬性中),那么您可以使用:按上次更新時間過濾以僅列出時間戳小于您將新屬性添加到的時間的實體你的 Go 模型。
另一種選擇(用于將來的更改)是"version"
向您的實體添加屬性。每當您執行模型更新時,都會增加新實體的版本。而且您始終可以使用舊版本(或特定版本)查詢實體。
- 1 回答
- 0 關注
- 239 瀏覽
添加回答
舉報
0/150
提交
取消