如何使用 elixir ets 创建复杂的查询

How to create complex queries with elixir ets

我使用 erlangs ets 功能缓存了一堆邮政编码和经纬度值。

图片如下...

iex()> :ets.new(:postcode_cache, [:named_table])
:postcode_cache
iex()> :ets.insert(:postcode_cache, [{"OX495NU", "latlongvalue"},{"M320JG", "latlongvalue"}])
true

这类似于我在我的应用程序中创建的 ets table。我想创建一个函数,该函数仅包含来自缓存的 selects 个条目,其中邮政编码包含用户输入内容的子字符串。有什么办法可以做到这一点,如果可以,我将如何实现这个功能?

(以后我可能只希望 select 使用 lat-long 值在一定距离内的值,但这超出了这个问题的范围)。

为清楚起见,table 类似于以下长生不老药列表...

iex()> postcode_list = [{"OX495NU","latlong"}, {"M320JG", "latlong"}]

我想用 ets 复制的功能是这样的...

iex()> Enum.filter(list, fn({postcode, _}) -> if String.contains?(postcode, "OX49") end)
[{"OX495NU", "latlong"}]

不能在匹配中调用任意函数,但这里您手头有一个可以与 :ets.foldl/3:

一起使用的匹配
:ets.foldl(fn
  {<<"0X49", _ :: binary>>, "latlong"} = n, acc -> [n | acc]
  _, acc -> acc
end, [], :named_table)