gpt4 book ai didi

erlang - 如何将元组内容与 qlc 和 mnesia 匹配?

转载 作者:行者123 更新时间:2023-12-01 02:59:56 25 4
gpt4 key购买 nike

我有这个记录的内存表。

-record(peer, {
peer_key, %% key is the tuple {FileId, PeerId}
last_seen,
last_event,
uploaded = 0,
downloaded = 0,
left = 0,
ip_port,
key
}).

Peer_key 是一个元组 {FileId, ClientId},现在我需要从所有具有特定 FileId 的 peer 中提取 ip_port 字段。

我想出了一个可行的解决方案,但我不确定这是否是一个好方法:
qlc:q([IpPort || #peer{peer_key={FileId,_}, ip_port=IpPort} <- mnesia:table(peer), FileId=:=RequiredFileId])

谢谢。

最佳答案

使用带元组主键(如 { FileId, PeerId })的 ordered_set 表类型,然后部分绑定(bind)元组的前缀(如 { RequiredFileId, _ })将非常有效,因为仅检查具有该前缀的键范围,而不是全表扫描。您可以使用 qlc:info/1 检查查询计划并确保正在发生的任何选择都绑定(bind)了键前缀。

关于erlang - 如何将元组内容与 qlc 和 mnesia 匹配?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1161831/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com