如何使用`jsonb_set`在嵌入式模式模型中执行原子更新?

时间:2016-10-10 12:04:43

标签: postgresql elixir phoenix-framework ecto

如何仅更新地图中的一个键,我想通过jsonb_set执行此操作:stackoverflow example或在事务中避免数据库中的潜在冲突,是否可以使用Ecto?

defmodule MySuperApp.Profile do
  use MySuperApp.Model
  schema "profiles" do
    field :name, :string
    embeds_one :settigns, MySuperApp.Settigns
  end
  def changeset(struct, params) do
    struct
    |> change
    |> put_embed(:settigns, MySuerApp.Settigns.changeset(model, params))
  end
end
defmodule MySuperApp.Settigns do
  use MySuperApp.Model

  @settigns %{socket: true, page: true, android: false, ios: false}

  embedded_schema do
    field :follow, :boolean

    field :action, :map, default: @settigns
  end

  def changeset(struct, _params) do
    # I would like to update only web key and leave old keys
    model |> change(action: %{web: false}) # this will override old map -> changes: %{action: %{web: false}
  end
end

1 个答案:

答案 0 :(得分:1)

没有。 Ecto目前不支持使用高级API(如更改集)对嵌入进行部分更新。

您可以通过Ecto.Adapters.SQL.query/4或更新版本Repo.query/3使用原始SQL查询来实现此目的。