首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

怎么提高根据文本的匹配返回数据的速度

2012-02-26 
如何提高根据文本的匹配返回数据的速度平台是MSSQL2000.有个个人资料的信息表,约有200w条记录。如何提高根

如何提高根据文本的匹配返回数据的速度
平台是MSSQL2000.

有个个人资料的信息表,约有200w条记录。
如何提高根据文本的匹配返回数据的速度。
比如我要查找姓“张”的人,或者名字里面带“泽”的人等等。
现在查询返回结果集的时间很长。

请问如何能提高返回速度。需要如何设置索引,需要什么格式的select的语句可以提高速度,是否需要应用到视图等等。
希望大家能给点建议,谢谢了。

[解决办法]
使用like , charindex等,对该列的索引失效.

查询办法为:

查找姓“张”的人

select * from tb where left(姓名,1) = '张'
select * from tb where 姓名 like '张%'

名字里面带“泽”的人

select * from tb where 姓名 like '%泽%'
select * from tb where charindex('泽' , 姓名) > 0

[解决办法]
看看~
[解决办法]

要不考虑用全文索引试一试!
[解决办法]

探讨
使用like , charindex等,对该列的索引失效.

查询办法为:

查找姓“张”的人

select * from tb where left(姓名,1) = '张'
select * from tb where 姓名 like '张%'

名字里面带“泽”的人

select * from tb where 姓名 like '%泽%'
select * from tb where charindex('泽' , 姓名) > 0

[解决办法]
建议用姓名字段建立全文索引。
因为复合索引在like查询时前面带%的情况下基本无效。

热点排行