[英]Query children of One-To-Many Relationship based on date along with parent
我的發電機表中有兩個實體:用戶和訂單。
每個user
有0..*
個訂單,每個order
都有一個關聯的user
。 每個order
還有一個orderDate
屬性,用於描述下訂單的時間。 我當前的表格結構如下,可以有效地檢索特定用戶的所有訂單:
+--------------+----------------+--------------------------------------+
| PK | SK | Attributes |
+--------------+----------------+-------------+-----------+------------+
| | | name | firstName | birthDate |
+--------------+----------------+-------------+-----------+------------+
| USER#userid1 | META#userid1 | Foo | Bar | 2000-10-10 |
+--------------+----------------+-------------+-----------+------------+
| | | orderDate | | |
+--------------+----------------+-------------+-----------+------------+
| USER#userid1 | ORDER#orderid1 | 2020-05-10 | | |
+--------------+----------------+-------------+-----------+------------+
我現在有第二種訪問模式,我想查詢在特定日期(例如2020-05-10
)放置的所有訂單(無論用戶如何)以及放置它們的用戶。
我正在努力在我的表格設計中處理這種訪問模式。 GSI 和不同的主鍵似乎在這里都不起作用,因為我要么必須每天復制每個用戶項目,要么不能與用戶一起查詢訂單。
我的問題有一個優雅的解決方案嗎?
不幸的是,我似乎無法找到優雅地解決您的問題的方法。
您需要復制用戶信息並存儲在訂單記錄中,或者使用第二個 getItem 來查詢用戶特定信息。
如果有人有更好的解決方案,請告訴我。
這是二級索引的完美用例。 這是一種方法:
您可以使用ORDERS#<orderDate>
的分區鍵 (GSI1PK) 和USER#<user_id>
的排序鍵 (GSI1SK) 在 Order 項目上創建二級索引 (GSI1)。 它看起來像這樣:
GSI1 的邏輯視圖如下所示:
GSI1 現在支持查詢在特定日期下的所有訂單。
請記住,非規范化數據 model(例如,在 Order 項目中重復用戶信息)是 DynamoDB 數據建模中使用的常見模式。 請記住,空間很便宜,更重要的是。 在這種情況下,您正在預先加入您的數據以支持您的應用程序訪問模式。 我會將您需要的任何用戶元數據添加到 Order 項目中,以便將其投影到索引中。
說得通?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.