我正在開發一個系統,該系統將在GAE上運行,該系統將具有多個相關實體,並且我不確定存儲數據的最佳方式。這篇文章是對其他人可能有類似經驗的建議的請求....尋找適用於Google App Engine的非規範化建議
該系統將有用戶,配置文件數據和圖像。這些用戶將能夠創建「事件」並向其添加日記條目。爲了系統的目的,「事件」可能會有1或2個日誌條目,超過10的條目可能永遠不會發生。其他用戶也可以向用戶的條目添加評論,其中流行的評論可能有數百甚至上千條評論。當一個隨機訪問者使用該系統時,他們應該能夠看到最新的事件(最新的,由最新的日記條目定義的),通過標籤進行搜索以及執行基本的文本搜索。然後,在選擇要查看的活動時,應該顯示所有日記條目和所有用戶評論,並在用戶圖片旁邊添加評論。用戶還應該有一個自我管理頁面,以查看/修改/刪除他們的事件,並查看/修改/刪除他們對其他事件做出的評論。因此,在正常的RDBMS上執行所有這些操作只需要在幾個表中進行一些大連接的查詢。在GAE上,顯然需要以不同的方式工作。下面是我在實體設計的初步想法:
- 事件實體 - ID,姓名,timstamp,列表的標籤 屬性,查看次數, 創建者的用戶名,創作者的個人資料 圖片ID,日記條目的數量 它包含,總評論 它包含的數量,最後更新包含日記條目,搜索的索引詞列表屬性(內置/從文本更新從包含日記帳分錄)
- JournalEntry的實體的時間戳 - , 雜誌文本,事件的名稱, 創建者的用戶名,創建者的配置文件Ë 圖片ID,評論 (含評論者的用戶名和 圖片ID)
- 用戶實體列表屬性 - 用戶名,密碼哈希,電子郵件,訂閱事件的列表屬性,創建日期,圖片ID,評論數的時間戳發佈,創建的事件的數量,創建日記條目的數量,最後雜誌活動的時間戳
- UserComment在實體 - 用戶名,事件的ID評論,事件的標題評論
- 對tagdata實體 - 標籤名,與標籤事件的數對他們
所以,我會升希望聽到人們在這裏思考設計,並且應該做出什麼樣的改變來幫助它的擴展。謝謝!
dfichter,感謝您提供了極好的建議,這正是我希望得到的結果。 回答你關於計數的問題,我相信我可以在沒有他們的情況下進行管理,因爲他們主要是爲了幫助用戶查看活動的位置。儘管如此,放棄它卻有點令人失望。你說的對,不得不創造許多獨立的交易才能完成一項單一的操作是過分的。我很樂意把它全部放在memcache中,但是我不能指望它真的在那裏,因爲這可能隨時消失。這是別人解決的常見問題嗎? – user605331 2011-02-06 20:52:51