在Ecto查询中正则表达式的正确语法是什么?

Pet*_*r R 7 elixir ecto phoenix-framework

这些都不起作用:

from m in Model, where: m.name == ^~r(/.*#{query}.*/i)

from m in Model, where: m.name =~ ^~r(/.*#{query}.*/i)

什么是正确的语法?我在文档中找不到任何内容.

fny*_*fny 12

由于您尝试匹配不区分大小写的短语,因此应使用ilike/2使用SQL LIKE运算符的短语:

from m in Model, where: ilike(m.name, "%#{query}%")
Run Code Online (Sandbox Code Playgroud)

like/2 将用于区分大小写的搜索.

Ecto不支持开箱即用的正则表达式,因为数据库之间的实现差别很大.您需要做的是查看您要定位的数据库的正则表达式语法,并使用Ecto自己构建该部分查询fragment/1.以下示例搜索匹配的所有模型/^Peter [A-Z]$/,使用PostgreSQL的POSIX正则表达式功能:

from m in Model, where: fragment('? ~ ?', m.name, '^Peter [A-Z]$')
Run Code Online (Sandbox Code Playgroud)