尝试实现“geo”postgrex扩展类型时出错

时间:2017-05-28 07:25:42

标签: postgresql elixir ecto elixir-framework postgrex

我正在关注this tutorial,它会在config.exs字段中添加一个postgrex扩展名。extensions。但是,现在这是添加postgrex扩展程序的弃用方式,我们现在应该使用type字段而不是extensions字段。我正在关注geo library github page上的代码,添加扩展程序:

config.exs

Postgrex.Types.define(MyApp.PostgresTypes,
  [Geo.PostGIS.Extension] ++ Ecto.Adapters.Postgres.extensions(),
  json: Poison)

use Mix.Config

config :api, Api.Repo,
  types: MyApp.PostgresTypes,
  adapter: Ecto.Adapters.Postgres,
  database: "api_repo",
  username: "postgres",
  password: "postgres",
  hostname: "localhost",
  web_port: String.to_integer(System.get_env("PORT") || "4000"),
  timeout: 60_000,
  pool_timeout: 60_000

config :api, ecto_repos: [Api.Repo]

但是我收到了这个错误:

bash-3.2$ mix ecto.migrate
** (Mix.Config.LoadError) could not load config config/config.exs
    ** (UndefinedFunctionError) function Ecto.Adapters.Postgres.extensions/0 is undefined (module Ecto.Adapt
ers.Postgres is not available)
    Ecto.Adapters.Postgres.extensions()
    (stdlib) erl_eval.erl:670: :erl_eval.do_apply/6
    (stdlib) erl_eval.erl:470: :erl_eval.expr/5
    (stdlib) erl_eval.erl:878: :erl_eval.expr_list/6
    (stdlib) erl_eval.erl:404: :erl_eval.expr/5
    (stdlib) erl_eval.erl:122: :erl_eval.exprs/5

我在网上看到这有时是由于version of postgrex,但这是一个非常旧的版本而我正在使用{:postgrex, "~> 0.13.2"},。我错过了什么?

1 个答案:

答案 0 :(得分:6)

定义自定义Postgrex类型的行需要放在使用您的应用程序(.exlib/中的任何内容)编译的web/文件中,而不是在配置文件中。配置文件无权访问应用程序的依赖项功能。

因此,如果您将此代码移至例如lib/my_app/postgres_types.ex

Postgrex.Types.define(MyApp.PostgresTypes,
  [Geo.PostGIS.Extension] ++ Ecto.Adapters.Postgres.extensions(),
  json: Poison)

您不应再得到未定义的函数错误,假设您已正确遵循geo包中的其余说明,一切都应该有效。