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

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

这些都不起作用:

来自模型中的m,其中:m.name == ^ ~r(/.*# {query}.* / i)

来自模型中的m,其中:m.name =〜^ ~r(/.*# {query}.* / i)

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

由于您尝试匹配不区分大小写的短语,因此应使用 ilike/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]$')

原文地址:https://www.jb51.cc/regex/356554.html

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

相关推荐