比较 Phoenix 控制器内的 Ecto 查询中的字符串 DateTime 参数

问题描述

不知道如何从 Phoenix 控制器内部将用户发布的 DateTime 字符串与 Postgresql 数据库中的 Ecto 'updated_at' 列进行比较。这是代码用户发布的 DateTime 字符串符合 NaiveDateTime 格式)...

defmodule Myapp.FooController do
  use MyappWeb,:controller
  alias Myapp.Repo
  alias Myapp.Foo
  import Ecto.Query


  def updates(conn,params) do

      query = from a in Foo,where: a.updated_at > ^params["date"]

      updates = Repo.all(query)

      json conn,updates

    end
  end

我没有找到解决这个问题的任何好办法。有两个使用 Timex 的 SO 示例,但我无法使该解决方案起作用。任何帮助深表感谢!我发现很难相信在我购买的书籍和其他文档中,没有任何必须是常见用例的示例。谢谢!

代码位于 Phoenix 1.5.8、Elixir 1.11.4、Erlang 23 erts 11.2。应用程序的所有其余部分都运行良好,只是这个 DateTime 比较导致了问题。

deps 是...

defp deps do
  [
  {:phoenix,"~> 1.5.8"},{:phoenix_ecto,"~> 4.1"},{:ecto_sql,"~> 3.4"},{:postgrex,">= 0.0.0"},{:phoenix_html,"~> 2.11"},{:phoenix_live_reload,"~> 1.2",only: :dev},{:phoenix_live_dashboard,"~> 0.4"},{:telemetry_metrics,{:telemetry_poller,{:gettext,"~> 0.11"},{:jason,"~> 1.0"},{:plug_cowboy,"~> 2.0"}
  ]
end

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)