好久没写点什么了。唉(此处省略无数,一切尽在苦逼中...)
说说sql中的全匹配优化吧。在sql server进行模糊查询的时候,如果是进行全匹配的话,那么肯定会用到like。我们知道like '%张' 这样的模糊查询的时候是无法使用到索引的,而like '张%'这样却可以。不能使用索引,如果数据量非常大的话,效率自然就低下了。这时候我们或许会想到CHARINDEX或者是PATINDEX这两个T-SQL函数,不过即使使用了依然是没有多大的效果的。
那么这时候可以考虑下逆转的概念。
具体操作:
比如模糊查询的条件是 张三 ,假设数据库customer表中name字段有 张三丰,陈张三,李四,王张五等值
正常写法
select * from customer where name like '%张三%' 那么查出来的值就是“张三丰和陈张三”
而逆转的写法
select * from customer where (name like '张三%' or reverse(name) like '三张%')
这是查出来的结果是不变的,但是查询的时间,经过200万条以上数据测试相差则上百倍。
测试正常写法差不多10秒,而逆转的写法则为20-35毫秒之间。
本文从百度空间搬家到博客园。。