`
ricy_cn
  • 浏览: 18807 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

几个良好的SQL书写习惯(转自网络)

阅读更多

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查询效率更高。

分享到:
评论

相关推荐

    Sql server 存儲過程技巧

    - 遵循良好的编码习惯,可以避免未来因版本升级等原因导致的兼容性问题。 #### 三、在存储过程中使用系统存储过程 SP_ExecuteSQL 的注意事项 SP_ExecuteSQL 是一个非常有用的系统存储过程,允许在 SQL Server 中...

    经典T-SQL语句练习

    这在需要进行数字与汉字互转的场景中非常有用,例如财务报表或者数据分析时,为了符合中国传统的书写习惯。函数内部使用了一个循环来逐位处理数字,并根据余数从预定义的字符串中提取相应的汉字,最后组合成结果。 ...

    人民币小写金额转大写

    这种转换不仅是为了符合中国的书写习惯,也是为了在正式的财务文档中避免金额被篡改的风险。本文将详细解析在SQL Server环境中实现这一功能的具体方法。 ### SQL Server中的人民币小写转大写函数 标题所提到的...

    此为本人学习node.js中书写的Demo,特此保存一下。采用AppCan MEAP移动应用开发平台开发,数据库采用.zip

    这可能涉及到以下几个关键知识点: 1. **Node.js基础**:理解JavaScript的基本语法,掌握Node.js的核心模块,如Express.js用于构建Web服务器,body-parser处理HTTP请求体,multer处理文件上传等。 2. **数据库操作...

    c#连接数据库,,并建立用户验证系统。这个是用户验证系统,我其它的在C#中向数据库中添加数据,修改数据,不过在其它我上传的文件中!!

    实训的重点包括以下几个方面: 1. **连接SQL Server数据库**:理解并掌握如何使用ADO.NET连接到SQL Server 2000数据库。 2. **连接字符串的书写**:学习如何正确配置连接字符串。 3. **数据库操作原理**:熟悉ADO...

    阿拉伯货币从数字到字母的转换

    针对“阿拉伯货币从数字到字母的转换”这个主题,我们主要会涉及到以下几个关键知识点: 1. **多语言支持**:在设计和开发面向全球用户的软件应用时,必须考虑多种语言,包括阿拉伯语。阿拉伯语是一种从右向左书写...

    MySql规范(系列一)

    7. **SQL语句尽可能简单**:避免复杂的SQL语句,可以将其拆分为多个简单的语句执行。 8. **简单的事务**:例如上传图片等操作不应该加入到事务中,以免增加不必要的事务开销。 9. **OR改写为IN()**:`OR`的操作效率...

    C#编码规范.doc

    在命名规则方面,有以下几个要点: 1. 函数、变量和类的名称应反映其实现的功能或用途,避免使用人名或项目组名。 2. 使用英文进行命名,避免使用下划线连接单词,而是采用PascalCase或CamelCase格式。 3. 避免使用...

    php编码规范

    文档规范主要包括以下几个方面: 1. **文件头部结构**:PHP文件通常以`开头,并在文件末尾以`?&gt;`结束。需要注意的是,建议在文件末尾不要添加不必要的换行符或空格,以防产生意外的空白输出。 2. **缩进**:统一...

    CVASP框架 201204C.zip

     提供几个下划线的代码生成工具:  _convutf8.asp --用于转换中文为UTF编码用于AJAX  _mkcvatpl.asp --用于生成编程时用的代码书写模板  _viewsrc.asp --用于查看cvcore.asp的源代码注释  具体效果用IIS...

    毕业设计任务书

    6. **良好编程习惯培养**:强调书写规范、易读的代码,以提高代码质量和可维护性。 7. **软件测试**:学生需要掌握基本的软件测试方法和技巧,确保系统的功能正确性和性能稳定性。 任务书还设定了具体的工作内容和...

    jsp外文翻译

    在毕业设计中使用JSP外文翻译,可能涉及到以下几个方面的知识: 1. **基础概念**:首先,你需要理解JSP的基础概念,包括JSP页面结构、指令元素(如page指令、include指令、taglib指令等)、动作元素(如jsp:include...

    2021-2022计算机二级等级考试试题及答案No.4889.docx

    根据给定文件的信息,我们可以总结出以下几个重要的知识点: ### 1. 域名系统(DNS)中的顶级域(TLDs) - **非营利组织的顶级域**:`.org` 代表非政府、非营利性的组织。此顶级域通常被非营利机构使用。 - **其他...

    11111111111111111111111111111111

    根据提供的文件内容,我们可以总结出以下几个关键知识点: ### 1. SQL 语言的基本组成部分 SQL(Structured Query Language)是一种用于管理关系型数据库的标准语言。它主要由四个部分组成: - **数据定义语言 ...

    PHP开发规范.pdf

    在PHP编码规范中,有以下几个关键点: 1. **代码标记**:推荐使用`&lt;?php ... ?&gt;`作为PHP代码的起始和结束标记,避免使用非标准的`和`?&gt;`,以确保代码的兼容性。 2. **注释**:提倡使用`/* ... */`和`//`进行多行和...

    什么是Linq表达式什么是Lambda表达式.pdf

    点标记(也被称为方法链语法或方法调用链)是LINQ中使用Lambda表达式的一种特定书写风格,通过一系列方法调用来连续表达查询操作。与查询表达式相比,点标记在语法上更加接近常规的编程结构。在点标记中,每个查询...

    阿里巴巴Java开发手册.rar

    手册的核心内容可以分为以下几个方面: 1. **基本规约**:这部分主要强调了Java编程中的基础规范,包括命名规则、注释规范、常量与变量的使用、异常处理等。例如,提倡使用有意义的英文命名,避免使用拼音或缩写;...

    讲的非常不错的PHP编码规范第1/3页

    具体来说,标准化可以带来以下几个方面的益处: - **易于理解**:标准化使得代码更容易被理解和维护。 - **快速适应**:新加入的成员能够更快地融入团队。 - **避免重复错误**:标准化有助于减少常见错误的发生。 -...

Global site tag (gtag.js) - Google Analytics