1. IS NULL 与 IS NOT NULL
不能用null作索引,任何包含null值的列都将不会被包含在索引中。即使索引有多列这样的情况下,只要这些列中有一列含有null,该列就会从索引中排除。也就是说如果某列存在空值,即使对该列建索引也不会提高性能。
任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。
2. 联接列
对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的。我们一起 来看一个例子,假定有一个职工表(employee),对于一个职工的姓和名分成两列存放(FIRST_NAME和LAST_NAME),现在要查询一个 叫比尔.克林顿(Bill Cliton)的职工。下面是一个采用联接查询的SQL语句:
select * from employss where first_name||''||last_name ='Beill Cliton'
上面这条语句完全可以查询出是否有Bill Cliton这个员工,但是这里需要注意,系统优化器对基于last_name创建的索引没有使用。
当采用下面这种SQL语句的编写,Oracle系统就可以采用基于last_name创建的索引。
Select * from employee where first_name ='Beill' and last_name ='Cliton'
遇到下面这种情况又如何处理呢?如果一个变量(name)中存放着Bill Cliton这个员工的姓名,对于这种情况我们又如何避免全程遍历,使用索引呢?可以使用一个函数,将变量name中的姓和名分开就可以了,但是有一点需 要注意,这个函数是不能作用在索引列上。下面是SQL查询脚本:
select * from employee
where
first_name = SUBSTR('&&name',1,INSTR('&&name',' ')-1)
and
last_name = SUBSTR('&&name',INSTR('&&name’,' ')+1)
3. 带通配符(%)的like语句
同样以上面的例子来看这种情况。目前的需求是这样的,要求在职工表中查询名字中包含cliton的人。可以采用如下的查询SQL语句:
select * from employee where last_name like '%cliton%'
这里由于通配符(%)在搜寻词首出现,所以Oracle系统不使用last_name的索 引。在很多情况下可能无法避免这种情况,但是一定要心中有底,通配符如此使用会降低查询速度。然而当通配符出现在字符串其他位置时,优化器就能利用索引。 在下面的查询中索引得到了使用:
select * from employee where last_name like 'c%'
4. Order by语句
ORDER BY语句决定了Oracle如何将返回的查询结果排序。Order by语句对要排序的列没有什么特别的限制,也可以将函数加入列中(象联接或者附加等)。任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。
仔细检查order by语句以找出非索引项或者表达式,它们会降低性能。解决这个问题的办法就是重写order by语句以使用索引,也可以为所使用的列建立另外一个索引,同时应绝对避免在order by子句中使用表达式。
5. NOT
我们在查询时经常在where子句使用一些逻辑表达式,如大于、小于、等于以及不等于等等,也可以使用and(与)、or(或)以及not(非)。NOT可用来对任何逻辑运算符号取反。下面是一个NOT子句的例子:
... where not (status ='VALID')
如果要使用NOT,则应在取反的短语前面加上括号,并在短语前面加上NOT运算符。NOT运算符包含在另外一个逻辑运算符中,这就是不等于(<>)运算符。换句话说,即使不在查询where子句中显式地加入NOT词,NOT仍在运算符中,见下例:
... where status <>'INVALID'
再看下面这个例子:
select * from employee where salary<>3000;
对这个查询,可以改写为不使用NOT:
select * from employee where salary<3000 or salary>3000;
虽然这两种查询的结果一样,但是第二种查询方案会比第一种查询方案更快些。第二种查询允许Oracle对salary列使用索引,而第一种查询则不能使用索引。
6. IN和EXISTS
有时候会将一列和一系列值相比较。最简单的办法就是在where子句中使用子查询。在where子句中可以使用两种格式的子查询。
第一种格式是使用IN操作符:
... where column in(select * from ... where ...);
第二种格式是使用EXIST操作符:
... where exists (select 'X' from ...where ...);
我相信绝大多数人会使用第一种格式,因为它比较容易编写,而实际上第二种格式要远比第一种格式的效率高。在Oracle中可以几乎将所有的IN操作符子查询改写为使用EXISTS的子查询。
第二种格式中,子查询以‘select 'X'开始。运用EXISTS子句不管子查询从表中抽取什么数据它只查看where子句。这样优化器就不必遍历整个表而仅根据索引就可完成工作(这里假定在where语句中使用的列存在索引)。相对于IN子句来说,EXISTS使用相连子查询,构造起来要比IN子查询困难一些。
通过使用EXIST,Oracle系统会首先检查主查询,然后运行子查询直到它找到第一个匹配项,这就节省了时间。Oracle系统在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。这也就是使用EXISTS比使用IN通常查询速度快的原因。
同时应尽可能使用NOT EXISTS来代替NOT IN,尽管二者都使用了NOT(不能使用索引而降低速度),NOT EXISTS要比NOT IN查询效率更高。
分享到:
相关推荐
- 遵循良好的编码习惯,可以避免未来因版本升级等原因导致的兼容性问题。 #### 三、在存储过程中使用系统存储过程 SP_ExecuteSQL 的注意事项 SP_ExecuteSQL 是一个非常有用的系统存储过程,允许在 SQL Server 中...
这在需要进行数字与汉字互转的场景中非常有用,例如财务报表或者数据分析时,为了符合中国传统的书写习惯。函数内部使用了一个循环来逐位处理数字,并根据余数从预定义的字符串中提取相应的汉字,最后组合成结果。 ...
这种转换不仅是为了符合中国的书写习惯,也是为了在正式的财务文档中避免金额被篡改的风险。本文将详细解析在SQL Server环境中实现这一功能的具体方法。 ### SQL Server中的人民币小写转大写函数 标题所提到的...
这可能涉及到以下几个关键知识点: 1. **Node.js基础**:理解JavaScript的基本语法,掌握Node.js的核心模块,如Express.js用于构建Web服务器,body-parser处理HTTP请求体,multer处理文件上传等。 2. **数据库操作...
实训的重点包括以下几个方面: 1. **连接SQL Server数据库**:理解并掌握如何使用ADO.NET连接到SQL Server 2000数据库。 2. **连接字符串的书写**:学习如何正确配置连接字符串。 3. **数据库操作原理**:熟悉ADO...
针对“阿拉伯货币从数字到字母的转换”这个主题,我们主要会涉及到以下几个关键知识点: 1. **多语言支持**:在设计和开发面向全球用户的软件应用时,必须考虑多种语言,包括阿拉伯语。阿拉伯语是一种从右向左书写...
7. **SQL语句尽可能简单**:避免复杂的SQL语句,可以将其拆分为多个简单的语句执行。 8. **简单的事务**:例如上传图片等操作不应该加入到事务中,以免增加不必要的事务开销。 9. **OR改写为IN()**:`OR`的操作效率...
在命名规则方面,有以下几个要点: 1. 函数、变量和类的名称应反映其实现的功能或用途,避免使用人名或项目组名。 2. 使用英文进行命名,避免使用下划线连接单词,而是采用PascalCase或CamelCase格式。 3. 避免使用...
文档规范主要包括以下几个方面: 1. **文件头部结构**:PHP文件通常以`开头,并在文件末尾以`?>`结束。需要注意的是,建议在文件末尾不要添加不必要的换行符或空格,以防产生意外的空白输出。 2. **缩进**:统一...
提供几个下划线的代码生成工具: _convutf8.asp --用于转换中文为UTF编码用于AJAX _mkcvatpl.asp --用于生成编程时用的代码书写模板 _viewsrc.asp --用于查看cvcore.asp的源代码注释 具体效果用IIS...
6. **良好编程习惯培养**:强调书写规范、易读的代码,以提高代码质量和可维护性。 7. **软件测试**:学生需要掌握基本的软件测试方法和技巧,确保系统的功能正确性和性能稳定性。 任务书还设定了具体的工作内容和...
在毕业设计中使用JSP外文翻译,可能涉及到以下几个方面的知识: 1. **基础概念**:首先,你需要理解JSP的基础概念,包括JSP页面结构、指令元素(如page指令、include指令、taglib指令等)、动作元素(如jsp:include...
根据给定文件的信息,我们可以总结出以下几个重要的知识点: ### 1. 域名系统(DNS)中的顶级域(TLDs) - **非营利组织的顶级域**:`.org` 代表非政府、非营利性的组织。此顶级域通常被非营利机构使用。 - **其他...
根据提供的文件内容,我们可以总结出以下几个关键知识点: ### 1. SQL 语言的基本组成部分 SQL(Structured Query Language)是一种用于管理关系型数据库的标准语言。它主要由四个部分组成: - **数据定义语言 ...
在PHP编码规范中,有以下几个关键点: 1. **代码标记**:推荐使用`<?php ... ?>`作为PHP代码的起始和结束标记,避免使用非标准的`和`?>`,以确保代码的兼容性。 2. **注释**:提倡使用`/* ... */`和`//`进行多行和...
点标记(也被称为方法链语法或方法调用链)是LINQ中使用Lambda表达式的一种特定书写风格,通过一系列方法调用来连续表达查询操作。与查询表达式相比,点标记在语法上更加接近常规的编程结构。在点标记中,每个查询...
手册的核心内容可以分为以下几个方面: 1. **基本规约**:这部分主要强调了Java编程中的基础规范,包括命名规则、注释规范、常量与变量的使用、异常处理等。例如,提倡使用有意义的英文命名,避免使用拼音或缩写;...
具体来说,标准化可以带来以下几个方面的益处: - **易于理解**:标准化使得代码更容易被理解和维护。 - **快速适应**:新加入的成员能够更快地融入团队。 - **避免重复错误**:标准化有助于减少常见错误的发生。 -...