免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2314 | 回复: 8
打印 上一主题 下一主题

字符串的三种匹配方法,哪种更快? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-11-08 14:21 |只看该作者 |倒序浏览
比如我有一个字段acc_nbr,是个varchar型的。要查找号码段在12345670-12345679之间的记录。

1、select * from mytable where acc_nbr[1,7] = '1234567'
2、select * from mytable where acc_nbr between  '12345670' and '12345679'
3、select * from mytable where acc_nbr like '1234567%'

我猜测是1,2次之,3最慢。大家分析分析。
过两天我给出试验结果。

论坛徽章:
0
2 [报告]
发表于 2006-11-09 04:07 |只看该作者
2最快吧?

论坛徽章:
0
3 [报告]
发表于 2006-11-09 10:17 |只看该作者
加上索引 都很快。

论坛徽章:
0
4 [报告]
发表于 2006-11-10 13:50 |只看该作者
当然,补充一点,都是没有索引的情况.

论坛徽章:
0
5 [报告]
发表于 2006-11-10 16:05 |只看该作者
1、3应该是基本相同的,2应该最慢

在数据量小的时候基本看不出差异,必须要大数据量才能说明问题

[ 本帖最后由 sunlan 于 2006-11-10 16:08 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2006-11-11 17:37 |只看该作者
原帖由 wenlq 于 2006-11-9 10:17 发表
加上索引 都很快。


即使加上索引,like '1234567%' 也不会使用吧..

论坛徽章:
0
7 [报告]
发表于 2006-11-11 19:19 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
8 [报告]
发表于 2006-11-16 15:40 |只看该作者
有索引1,3差不多是一样的,2难说,感觉应该会慢一些,不过既然都是数字,为什么不用数字型字段用什么varchar,可以肯定的是2这个sql在数字型字段上肯定要比2在字符型上快很多,至于不加索引那当然都一样,都是顺序扫描
zimb 该用户已被删除
9 [报告]
发表于 2006-11-17 16:01 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP