Ecto Repo.get_by 带有多个 'or' 子句
Ecto Repo.get_by with multple 'or' clauses
我正在尝试将 Ecto Repo.get_by 与多个子句一起使用,但找不到语法示例。我需要查询数据库中的一个或两个字段匹配的位置,因此子句之间有一个 'or' 条件。我不知道这是否可能。
Repo.get_by(User, [username: username, email: username], prefix: :accounts)
Repo.get_by
不允许 OR
ing 从句。您需要使用 from
或 where
和 or_where
的组合编写完整查询,然后通过管道传输到 Repo.one
:
from(u in User, where: u.username == ^username or u.email == ^username)
|> Repo.one
User
|> where(username: ^username)
|> or_where(email: ^username)
|> Repo.one
要将前缀添加到此查询,您可以执行 this。
我正在尝试将 Ecto Repo.get_by 与多个子句一起使用,但找不到语法示例。我需要查询数据库中的一个或两个字段匹配的位置,因此子句之间有一个 'or' 条件。我不知道这是否可能。
Repo.get_by(User, [username: username, email: username], prefix: :accounts)
Repo.get_by
不允许 OR
ing 从句。您需要使用 from
或 where
和 or_where
的组合编写完整查询,然后通过管道传输到 Repo.one
:
from(u in User, where: u.username == ^username or u.email == ^username)
|> Repo.one
User
|> where(username: ^username)
|> or_where(email: ^username)
|> Repo.one
要将前缀添加到此查询,您可以执行 this。