在SQL语句中,是否应该使用LIKE或'='来比较字符串,这是一个(几乎是宗教式的)讨论。
有使用LIKE的理由吗? 有使用'='的理由吗? 性能?可读性呢?
在SQL语句中,是否应该使用LIKE或'='来比较字符串,这是一个(几乎是宗教式的)讨论。
有使用LIKE的理由吗? 有使用'='的理由吗? 性能?可读性呢?
当前回答
LIKE和相等运算符有不同的目的,它们做的事情不一样: =更快,而LIKE可以解释通配符。在你能使用的地方使用=,在你必须使用的地方使用LIKE。
SELECT * FROM user WHERE login LIKE 'Test%';
样本匹配:
测试用户1 测试用户2 测试U 测试
其他回答
LIKE在shell中匹配像通配符char [*, ?] LIKE '%suffix' -给我所有以后缀结尾的东西。你不能用= 这要看具体情况了。
对于模式匹配使用LIKE。对于精确匹配=。
在我的小经验中:
“=”表示精确匹配。
“LIKE”表示部分匹配。
要查看性能差异,请尝试以下方法:
SELECT count(*)
FROM master..sysobjects as A
JOIN tempdb..sysobjects as B
on A.name = B.name
SELECT count(*)
FROM master..sysobjects as A
JOIN tempdb..sysobjects as B
on A.name LIKE B.name
用'='比较字符串要快得多。
LIKE和相等运算符有不同的目的,它们做的事情不一样: =更快,而LIKE可以解释通配符。在你能使用的地方使用=,在你必须使用的地方使用LIKE。
SELECT * FROM user WHERE login LIKE 'Test%';
样本匹配:
测试用户1 测试用户2 测试U 测试