我尝试将两个ETS表合并为一个ETS表。我知道的唯一方法是创建第三个表,并将两个表的记录插入第三个表格中。有更好的方法吗?
ets:insert允许一个元组列表。另一方面,ets:tab2list将ets表导出为元组列表。这意味着您可以轻松地将一个ets表导入另一个表。
不完全是一个并集,但您最终会得到一个包含前两个并集的表,而不会创建第三个ets表,这似乎是您试图实现的。
一个小例子:
ets:new(list_a,[named_table]).
ets:new(list_b,[named_table]).
ets:insert(list_a,{one,1}).
ets:insert(list_b,{two,2}).
ets:insert(list_b,{three,3}).
ets:insert(list_a,ets:tab2list(list_b)).
ets:tab2list(list_a).
% list_a = [{three,3},{two,2},{one,1}]
如果密钥相同,会发生什么取决于您使用的ETS表的类型(erlang doc):
如果表是一个集合,并且插入对象的键与键,则旧对象将被替换。如果该表是ordered_set,是插入对象的键比较等于表中任何对象的键,即旧对象也被替换。如果列表包含多个具有匹配的键和表是一组,会插入一个,哪一个未定义。ordered_set也是如此,但如果键比较相等,就会发生这种情况。
此外,您可能希望使用ets:insert_new,它不会覆盖。