2017-02-10 57 views
0

我有postgres运行,并可以连接到它,但通过mix phoenix.new reporting连接到一个全新的凤凰应用程序。我无法完成设置,不能完成ecto.create,我能告诉的最好的是它没有连接到数据库......或者它可能是一些其他的bug ...... bascially,我不知道该从哪里去。菲尼克斯设置失败:编译错误,(KeyError)键:没有找到模型

$ psql -p 5432 -h localhost reporting_dev postgres 
Password for user postgres: 
psql (9.6.1, server 9.6.2) 
Type "help" for help. 

reporting_dev=# 

这里是我的config/dev.exs

$ grep Reporting.Repo -A 6 config/dev.exs 
config :reporting, Reporting.Repo, 
    adapter: Ecto.Adapters.Postgres, 
    username: "postgres", 
    password: "postgres", 
    database: "reporting_dev", 
    hostname: "localhost", 
    pool_size: 10 

,但我无法完成ecto.create

$ mix ecto.create 
warning: variable "aliases" does not exist and is being expanded to "aliases()", please use parentheses to remove the ambiguity or change the variable name 
    mix.exs:12 

warning: variable "deps" does not exist and is being expanded to "deps()", please use parentheses to remove the ambiguity or change the variable name 
    mix.exs:13 

warning: variable "deps" does not exist and is being expanded to "deps()", please use parentheses to remove the ambiguity or change the variable name 
    /Users/alan/Code/eltoro/reporting/deps/phoenix_ecto/mix.exs:10 

warning: variable "package" does not exist and is being expanded to "package()", please use parentheses to remove the ambiguity or change the variable name 
    /Users/alan/Code/eltoro/reporting/deps/phoenix_ecto/mix.exs:14 

==> phoenix_ecto 
Compiling 4 files (.ex) 

== Compilation error on file lib/phoenix_ecto/html.ex == 
** (KeyError) key :model not found in: %Phoenix.HTML.Form{data: nil, errors: {{:., [line: 12], [{:changeset, [line: 12], nil}, :errors]}, [line: 12], []}, hidden: [], id: {:name, [line: 10], nil}, impl: Phoenix.HTML.FormData.Ecto.Changeset, index: nil, name: {:name, [line: 11], nil}, options: [], params: %{}, source: {:changeset, [line: 8], nil}} 
    (stdlib) :maps.update(:model, {:model, [line: 13], nil}, %Phoenix.HTML.Form{data: nil, errors: {{:., [line: 12], [{:changeset, [line: 12], nil}, :errors]}, [line: 12], []}, hidden: [], id: {:name, [line: 10], nil}, impl: Phoenix.HTML.FormData.Ecto.Changeset, index: nil, name: {:name, [line: 11], nil}, options: [], params: %{}, source: {:changeset, [line: 8], nil}}) 
    lib/phoenix_html/form.ex:170: anonymous fn/2 in Phoenix.HTML.Form.__struct__/1 
    (elixir) lib/enum.ex:1755: Enum."-reduce/3-lists^foldl/2-0-"/3 
    expanding struct: Phoenix.HTML.Form.__struct__/1 
    lib/phoenix_ecto/html.ex:7: Phoenix.HTML.FormData.Ecto.Changeset.to_form/2 

could not compile dependency :phoenix_ecto, "mix compile" failed. You can recompile this dependency with "mix deps.compile phoenix_ecto", update it with "mix deps.update phoenix_ecto" or clean it with "mix deps.clean phoenix_ecto" 

这里是我的基本版本

$ elixir -v 
Erlang/OTP 19 [erts-8.2] [source] [64-bit] [smp:8:8] [async-threads:10] [hipe] [kernel-poll:false] [dtrace] 

Elixir 1.4.1 

$ uname -a 
Darwin alan-MBP.local 15.6.0 Darwin Kernel Version 15.6.0: Mon Jan 9 23:07:29 PST 2017; root:xnu-3248.60.11.2.1~1/RELEASE_X86_64 x86_64 i386 MacBookPro11,5 Darwin 

$ node --version 
v6.7.0 
+1

你确定你是在最新的凤凰? ('mix phoenix.new -v'应该打印1.2.1) – Dogbert

+0

确实这是最新的版本'Phoenix v1.2.1' – zeroasterisk

回答

0

难道塔你使用的是1.x版本的Phoenix.HTML,你应该使用2.x版本。

在版本1.x中,使用术语模型,而不是模式,该模式在2.x和最新的Phoenix版本中使用。

https://github.com/phoenixframework/phoenix_html/blob/v1.4.0/lib/phoenix_html/form.ex#L166

VS

https://github.com/phoenixframework/phoenix_html/blob/v2.9.3/lib/phoenix_html/form.ex#L170

+0

我不知道。从字面上看,我只是在阅读入门自述文件后,陷入了困境。我可以尝试下一个版本...有没有指导呢? – zeroasterisk