微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么 Ecto.Repo 进程不需要`send/receive`?

如何解决为什么 Ecto.Repo 进程不需要`send/receive`?

当使用 Ecto 进行数据库查询时,我们将使用类似 Users.Repo.get!(id) 的东西,这当然有效,但为什么我不需要需要 send/receive 与 {{ 1}} 过程?为什么我可以像引用模块和函数名称一样简单地调用它?

Users.Repo一个 OTP 应用程序,其中 UsersUsers.Application 进程加载为 Users.Repo 进程的子进程

Users.Supervisor

解决方法

Users.RepoEcto.Repo 注入 use Ecto.Repo,因此默认 get/3 实现是 delegatedEcto.Repo.Queryable.get/3,然后下降到 {{3} }.

adapter 反过来已经是一个 adapter.execute/5 并且 execute/5 是一个在后台调用的进程的接口。该抽象级别需要为您封装连接池、超时、错误处理等。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。