2 回答

TA貢獻(xiàn)1859條經(jīng)驗(yàn) 獲得超6個(gè)贊
根據(jù)您查詢的方式,您可以執(zhí)行以下操作:
在你的結(jié)構(gòu) A 添加一個(gè)字段:
BIds []int64
在你的結(jié)構(gòu) B 添加一個(gè)字段:
AIds []int64
現(xiàn)在,每當(dāng)您在 A 和 B 之間添加關(guān)系時(shí),您只需要將相應(yīng)的 id 添加到您的兩個(gè)變量中
當(dāng)您現(xiàn)在需要查詢與此 A1 相關(guān)的所有 B 時(shí),您可以像這樣進(jìn)行查詢:
SELECT * FROM B where AIds = 'A1'
對(duì)于與此 B1 相關(guān)的所有 A,您的操作類似:
SELECT * FROM A where BIds = 'B1'
更新:
更改了對(duì)來自 Dragonx 的建議的查詢

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超21個(gè)贊
python ReferenceProperty 本質(zhì)上存儲(chǔ)另一個(gè)實(shí)體的鍵。這類似于在 Go 中使用 Key 字段。
至少有兩種方法可以解決您的問題。一種存儲(chǔ)有限數(shù)量引用的廉價(jià)方式,以及一種用于較大數(shù)據(jù)集的昂貴方式。
fmt.Println.MKO 提供了廉價(jià)方式的答案,除了查詢比他建議的更簡(jiǎn)單之外,它實(shí)際上應(yīng)該是:
SELECT * FROM B where AIds = 'A1'
此方法僅限于每個(gè)實(shí)體的索引條目數(shù)以及實(shí)體大小。因此,Aid 或 BId 列表會(huì)將實(shí)體數(shù)量限制為 20000 或更少。
如果您有大量數(shù)據(jù),您可能需要一個(gè)映射實(shí)體來表示給定 A 和 B 實(shí)體之間的 M2M 關(guān)系。它只包含一個(gè) A 的鍵和一個(gè) B 的鍵。然后您將查詢地圖實(shí)體,然后獲取您需要的相應(yīng) A 或 B 實(shí)體。這會(huì)更昂貴,但突破了實(shí)體大小限制。
- 2 回答
- 0 關(guān)注
- 178 瀏覽
添加回答
舉報(bào)