【问题标题】:What's the correct syntax for Regex in an Ecto Query?Ecto 查询中正则表达式的正确语法是什么?
【发布时间】:2016-08-12 03:19:06
【问题描述】:

这些都不起作用:

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

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

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

【问题讨论】:

    标签: elixir phoenix-framework ecto


    【解决方案1】:

    由于您尝试匹配不区分大小写的短语,您应该使用ilike/2,它使用SQL LIKE operator

    from m in Model, where: ilike(m.name, "%#{query}%")
    

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

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

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

    【讨论】:

      猜你喜欢
      • 2014-08-01
      • 1970-01-01
      • 1970-01-01
      • 2013-04-07
      • 2013-05-12
      • 2016-08-18
      • 2011-06-15
      相关资源
      最近更新 更多