簡體   English   中英

根據日期與父對象一起查詢一對多關系的子對象

[英]Query children of One-To-Many Relationship based on date along with parent

我的發電機表中有兩個實體:用戶和訂單。

每個user0..*個訂單,每個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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM