MySQL正則表達式(regexp)和模糊查詢(like)都是查詢語句中常用的操作符。它們不同的地方在于,regexp可以更精確地匹配字符串,而like只能匹配通配符。
MySQL正則表達式使用的語法基于POSIX風格的正則表達式,可以使用一些特殊的元字符和量詞來匹配字符串。比如,元字符"."可以匹配任意一個字符,"*"可以匹配零個或多個相鄰字符。
下面是一個使用regexp的例子,它會查找表中col1列中以a開頭的字符串:
SELECT * FROM mytable WHERE col1 REGEXP '^a';
與此相對,like操作符只支持通配符匹配。比如,可以使用"%"通配符匹配任意字符,"_"匹配單一字符。下面是一個使用like操作符的例子,它會查找表中col2列中以a開頭的字符串:
SELECT * FROM mytable WHERE col2 LIKE 'a%';
請注意,在某些情況下,使用like和regexp操作符可能會對性能造成不良影響。因此,在使用它們時,應該謹慎地選擇合適的操作符,并對查詢的字段添加合適的索引以提高查詢的性能。