我有这个记录的内存表。
-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/