林易陞:怎样提高SQLSERVER的like查询速度?

来源:百度文库 编辑:杭州交通信息网 时间:2024/05/04 05:26:04
一堆新闻,需要经常用like语句查询标题,一般的索引可以提高查询速度吗?我感觉只能是提高“=”这样的查询速度。谢谢!+30分

索引可以提高的,like的话要看是“%abc%”还是“abc%”的,前者速度比较慢,后者就快了,和“=”差不多,前者可以用全文索引来弥补
还可以用Top n来查询,提高速度

如果是使用like进行查询的话,简单的使用index是不行的,但是全文索引,耗空间。 like ''a%'' 使用索引, like ''%a'' 不使用索引用 like ''%a%'' 查询时,查询耗时和字段值总长度成正比,所以不能用CHAR类型,而是VARCHAR。对于字段的值很长的需要建全文索引。

SQL语句只要有 LIKE 关键字就会破坏其索引,这也是SQL最大的弊端,想要高效率全文检索的话,可以尝试一些专门的检索系统:如 Lucence