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

本文解釋了GO的軟件包導入機制:命名imports(例如導入“ fmt”)和空白導入(例如導入_ fmt; fmt;)。 命名導入使包裝內容可訪問,而空白導入僅執行t

本文解釋了Beego的NewFlash()函數,用於Web應用程序中的頁間數據傳輸。 它專注於使用newflash()在控制器之間顯示臨時消息(成功,錯誤,警告),並利用會話機制。 Lima

本文詳細介紹了MySQL查詢結果的有效轉換為GO結構切片。 它強調使用數據庫/SQL的掃描方法來最佳性能,避免手動解析。 使用DB標籤和Robus的結構現場映射的最佳實踐

本文演示了創建模擬和存根進行單元測試。 它強調使用接口,提供模擬實現的示例,並討論最佳實踐,例如保持模擬集中並使用斷言庫。 文章

本文探討了GO的仿製藥自定義類型約束。 它詳細介紹了界面如何定義通用功能的最低類型要求,從而改善了類型的安全性和代碼可重複使用性。 本文還討論了局限性和最佳實踐

本文詳細介紹了在GO中詳細介紹有效的文件,將OS.WriteFile(適用於小文件)與OS.openfile和緩衝寫入(最佳大型文件)進行比較。 它強調了使用延遲並檢查特定錯誤的可靠錯誤處理。

本文使用跟踪工具探討了GO應用程序執行流。 它討論了手冊和自動儀器技術,比較諸如Jaeger,Zipkin和Opentelemetry之類的工具,並突出顯示有效的數據可視化


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Linux新版
SublimeText3 Linux最新版