a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 142|回复: 0

[考试辅导] Oracle技术:Oracle中慎用Like等通配符

[复制链接]
发表于 2012-8-4 14:06:19 | 显示全部楼层 |阅读模式
 Like关头字,年夜手艺上来说,是一个很是友善的通配符。操作这个通配符,我们可以实现良多恍惚发芽。如斯刻在一小我事档案系统中,用户想知道身份证号码以“339005”开首的人事信息,此时,就可以操作Like语句实现。我们可以操作下面的前提语句,实现我们的需求,“where 身份证号码 like ‘339005%’”。经由过程这个前提语句,可以查到所怀孕份证以339005开首的号码。% R- A: U9 ?: {) }) N- y& @5 J& U% v" P
  可是,当用户在一张年夜表中采用这个LIKE语句的话,就会发现这个发芽语句的运行效率很是的慢。这是什么原因造成的呢?其实,不管是Like 关头字,若采用MATCHES关头字的话,若在年夜量数据中查找合适前提的记实,则其运行效率也斗劲低。这主若是其手艺特征所造成的。
. v6 Q% C! u4 Z0 F* @  Like与Matches两个关头字,其撑持通配符匹配。在有些专业书籍上把这个叫做“正规表达式”。不外因为在操作这些关头字发芽的时辰, 数据库系统不是经由过程索引来发芽,而是采用挨次扫描的体例来发芽。显然,真是这种手艺特征,造成了Like与Mateches两个关头字发芽效率的低下。出格是在复杂发芽或者年夜表发芽中,用户可以较着感受到速度斗劲慢。
0 o: o" ~4 ?7 ~; g4 X2 D% V  索引是数据库中的一个主要的数据结构。索引如不美观操作的合理的话,可以年夜幅度的晋升数据库的发芽机能。一般情形下,我们在数据库设计的时辰,要充实的操作索引,来提高数据库的运行效率。如对于一些经常需要用到的发芽功能,我们需要为没有指定外键的列成立索引;若有发芽年夜表数据,而且又需按照好几个字段的值对其进行排序,也需要在这些列上成立复合索引。出格是在一些应用系统上,往往可以按以下字段的名称,就会对这个字段进行排序。碰着这种情形的话,加倍需要在这些频仍进行排序的列上成立索引,以提高巨子排序的效率。可见,若在发芽的时辰,若不能操作索引提高发芽效率的话,则就仿佛跑车失踪去四轮驱动,速度会年夜受影响。
' s# ~3 h% I6 b  所以,在数据库系统设计中,要尽量避免采用Like或者Matche关头字。有时辰,我们可以操作其他运算符号来庖代。如我们可以操作〉(年夜于)或者
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-5-4 18:15 , Processed in 0.255258 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表