这些都不起作用:
来自模型中的m,其中:m.name == ^ ~r(/.*# {query}.* / i)
来自模型中的m,其中:m.name =〜^ ~r(/.*# {query}.* / i)
什么是正确的语法?我在文档中找不到任何内容.
由于您尝试匹配不区分大小写的短语,因此应使用
原文链接:https://www.f2er.com/regex/356554.htmlilike/2
使用
SQL LIKE operator:
from m in Model,where: ilike(m.name,"%#{query}%")
喜欢/ 2将用于区分大小写的搜索.
Ecto不支持开箱即用的正则表达式,因为数据库之间的实现差别很大.您需要做的是查看您要定位的数据库的正则表达式语法,并使用Ecto fragment/1
自己构建查询的这一部分.以下示例搜索匹配的所有模型/ ^ Peter [AZ ] $/,使用PostgreSQL’s POSIX regex feature:
from m in Model,where: fragment('? ~ ?',m.name,'^Peter [A-Z]$')