我需要找到存储在 postgres 中的所有记录,这些记录与以下正则表达式匹配:
^((8|\+7)[\- ]?)?(\(?\d{3}\)?[\- ]?)?[\d\- ]{7,10}$
像这样的东西:
SELECT * FROM users WHERE users.phone ~ '^((8|\+7)[\- ]?)?(\(?\d{3}\)?[\- ]?)?[\d\- ]{7,10}$'
但是这个错误:
无效的正则表达式:量词操作数无效
为什么 Postgres 不能使用这个正则表达式?
在普通的 Ruby 中使用相同的就可以了。
更新
问题只出在 WHERE 上。当我尝试:
SELECT '+79637434199' ~ '^((8|\+7)[\- ]?)(\(?\d{3}\)?[\- ]?)[\d\- ]{7,10}'
Postgres 返回真。但是当我尝试时:
SELECT * FROM users WHERE users.phone ~ '^((8|\+7)[\- ]?)(\(?\d{3}\)?[\- ]?)[\d\- ]{7,10}'
结果:“无效的正则表达式:量词操作数无效”。