首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在数据库中存储映射中的模块名称

在数据库中存储映射中的模块名称
EN

Stack Overflow用户
提问于 2019-05-31 14:50:28
回答 1查看 65关注 0票数 0

我正在使用Elixir/Ecto/Phoenix为物联网应用程序创建通知服务。此应用程序中的传感器可以有多个值,例如

代码语言:javascript
复制
temperature: ["temp"],
accelerometer: ["ax", "ay", "az"]

要创建通用通知策略,我必须将模块名称与传感器存储在一起,传感器将实现处理资格规则的逻辑。此外,由于每个传感器可以有多个与其关联的值accelerometer -> ax, ay, az,因此对于不同的值,模块可以不同。

代码语言:javascript
复制
  schema("acqdat_sensor_notifications") do
    field(:rule_values, :map)
    field(:alarm_status, :boolean, default: false)
    belongs_to(:sensor, Sensor, on_replace: :delete)

    timestamps()
  end

规则值列将以以下格式存储数据,例如加速度传感器的数据。

代码语言:javascript
复制
%{
  "ax" => %{ 
    module: "NotificationPolicyA", 
    module_preferences: {"prefA": valuea, "prefb": valueb}
  },
  "ay" => %{ 
    module: "NotificationPolicyB", 
    module_preferences: {"pref1": value1, "pref2": value2}
  },
}

这里的问题是存储将处理逻辑的模块名称。我不能使用像ecto_enum这样的枚举库,因为值存储在jsonb映射中,这不是常量(这里不能使用嵌入)。它会随着传感器名称和用于处理它的模块而不断变化。

目前我正在使用地图进行处理。

代码语言:javascript
复制
%{
  NotificationPolicyA: 0, 
  NotificationPolicyA: 1 
  .
  .
  .
}

然后将这些整数存储在db中,以便如果模块名称被修改,则仅改变映射。

代码语言:javascript
复制
"ax" => %{ 
    module: 0, 
    module_preferences: {"prefA": valuea, "prefb": valueb}
  }

使用ecto处理这种情况的替代方法是什么?

EN

回答 1

Stack Overflow用户

发布于 2019-05-31 21:40:29

您可以将模块名称以字符串形式存储在数据库中,使用String.to_existing_atom/1进行转换,使用Kernel.apply/3运行所需的任何函数。

示例:

代码语言:javascript
复制
iex(2)> apply(String.to_existing_atom("Elixir.MyApp.Version"), :run, [1])
0.29.1
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56390063

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档