PostgreSQL LIKE 子句中的正则表达式
您的表达式旨在匹配以“00”开头并后跟 1 到 1 之间的数字的字符串9,但不包括第三个字符为“0”的字符串。错误的表达式是:
select * from table where value like '00[1-9]%'
LIKE 运算符的错误用法:
PostgreSQL 中的正则表达式运算符使用波形符 (~) 而不是 LIKE。要使用括号表达式,需要将运算符更改为 ~.
改进的正则表达式:
SELECT * FROM table WHERE value ~ '^00[^0]'
替代方案使用 LIKE:
您可以使用 LIKE 运算符与否定结合使用,而不是正则表达式:
SELECT * FROM table WHERE value LIKE '00%' -- Starts with '00' AND value NOT LIKE '000%' -- Excludes third character '0'
对于简单模式,此方法通常比正则表达式更快。
索引优化:
Postgres 支持以下索引左锚定的 LIKE 表达式,例如“00%”。索引可以显着提高大型表的性能。正则表达式可能并不总是使用索引,因此值得考虑使用 LIKE 替代方案以获得更好的索引机会。
以上是PostgreSQL 中如何高效匹配以'00”开头且第三位非零的字符串?的详细内容。更多信息请关注PHP中文网其他相关文章!