在实际应用中。数据库中的数据会有非常多。若要从这些数据表中检索数据,就须要对系统进行优化,提高数据库系统的响应速度,以下就是日常一些查询优化的方法。

1.创建索引

索引能够提高数据库查询的速度,提高数据库的訪问性能,但同一时候也会影响数据更新操作(比如插入、改动、删除)的速度。

  1. 假设WHERE子句中经经常使用到的某一列或者某几列创建索引

  2. 为数据表中常常须要运行排序操作的列创建索引

  3. 多表连接时。应该为数据表的连接列创建索引

  4. 对于须要不断更新的列,则不建议创建索引

2.优化查询语句

  1. 避免在SELECT语句中使用“*”

  2. 在使用SELECT语句时,应该在SELECT语句之后将要查询的信息一一列出来,即使要查询全部列的信息。也最好不要使用,从可读性上讲,方便用户对所要查询数据的理解。

  3. 调整WHERE子句中连接条件的顺序

    在SQL语句查询中,使用最多的就应该是WHERE子句。连接条件顺序的不同也会影响数据的查询效率。

比如:查询员工工资表中工资在1000到3000的员工记录



语句一

select empno,eName,salary
from employee
where salary>1000
and salary<3000

语句二

select empno,eName,salary
from employee
where salary<3000
and salary>1000

我们看到这两条语句。查询的结果是全然同样的。可是查询效率确实不一样的,假设员工工资都在1000元以上的话,那么我们就不言而喻了,第二条语句直接就缩小了查询范文。

注意:在使用WHERE子句进行查询时,要把限制性最高的查询条件放在最前面

3.多表联合查询



样例:

select stuid,curid ,curName,result
from t_result r,t_curriculum t
where t.curid=t.curid --应该将表与表联合放在前面
and t.stuid='123'

注意:在多表连接时。应该将表与表的结合操作放在WHERE子句的前面。后面才是过滤语句



4.避免使用ORkeyword

匹配记录时。能够有两种方式,一种使用OR,还有一种使用In,使用Inkeyword能够提高数据的查询速度

比如:

select empno,eName
from employee
where eptno=10
or eptno=15

IN语句

select empno,eName
from employee
where eptno in(10,15)--相当于创建了索引

5.避免使用<>和!=操作符

比如:查询教师工资不为3000的教师记录

这样的查询不是使用索引。而是直接查询数据库中的数据,应该用以下这样的形式

select empno,eName,salary
from employee
where salary<3000
or salary>3000

注意:在实际应用中。应该尽量使用<、>等操作符而不是<>

相关子查询中使用EXISTSkeyword取代INkeyword

比如查询选修课程编号为105这门课的学生信息。



6.EXISTSkeyword查询



样例一:查询课程编号为105课程的信息



EXISTS语句

select s.stuid,s.stuName,s.age,s.sex
from t_student s
where exists
(select *
from t_result t where
s.stuid=t.stuid and t.curid='t105')

IN语句

select s.stuid,s.stuName,s.age,s.sex
from t_student s
where s.stuid in
(select *
from t_result t where
s.stuid=t.stuid and t.curid='t105')

原因:在运行带有INkeyword的子查询时。数据库会首先运行子查询操作,将查询结果放到一个暂时表中,主查询会在子查询运行完成后再运行。而带有EXISTSkeyword的相关子查询则是先检查主查询的第一条记录,通过子查询进行匹配。这个过程会重复运行,知道子查询所有检查完成。这样就节省了时间。



7.使用LIKEkeyword

使用LIKEkeyword实现模糊查询时。须要注意一下。

比如查询学生编号中含有数字100的学生信息的两种方法

方法一

select stuid,stuName,age
from t_student
where stuid like '%100%'

方法二

 select stuid,stuName,age
from t_student
where stuid like 's100%'

注意:在实际应用中或许必需要实现第一种查询方法才干满足,这里仅仅是让大家知道这样会减少查询的效率。

8.避免使用HAVING子句

HAVING子句是用来对分组后的结果进行过滤,限制分组后的查询结果。在使用时一般须要运行排序,统计等功能。这就会消耗SQL额外工作。因此应该避免使用这些操作

使用存储过程

存储过程是经过编译的,永久保存在数据中的一组SQL语句。使用存储过程运行效率要比SQL语句运行效率高



小结:以上仅仅是一部分SQL语句来改善数据库性能的方法,后面还会有相关的文章,敬请期待。

SQL之性能优化的更多相关文章

  1. SQL Server 性能优化(一)——简介

    原文:SQL Server 性能优化(一)--简介 一.性能优化的理由: 听起来有点多余,但是还是详细说一下: 1.节省成本:这里的成本不一定是钱,但是基本上可以变相认为是节省钱.性能上去了,本来要投 ...

  2. SQL Server 性能优化之——系统化方法提高性能

    SQL Server 性能优化之——系统化方法提高性能 阅读导航 1. 概述 2. 规范逻辑数据库设计 3. 使用高效索引设计 4. 使用高效的查询设计 5. 使用技术分析低性能 6. 总结 1. 概 ...

  3. SQL Server性能优化与管理的艺术 附件下载地址

    首先感谢读者们对鄙人的支持,购买了<SQL Server性能优化与管理的艺术>,由于之前出版社的一些疏忽,附件没有上传成功,再次本人深表歉意. 请需要下载附件的读者从下面链接下载,谢谢: ...

  4. Mybatis动态sql及性能优化-3

    内容简介 1.回顾 2.动态sql 3.性能优化 懒加载机制 一级缓存 二级缓存 一.回顾 1.config文件常用标签 properties标签:引入外部properties文件资源. settin ...

  5. SQL Server性能优化(6)查询语句建议

    1. 如果对数据不是工业级的访问(允许脏读),在select里添加 with(nolock) ID FROM Measure_heat WITH (nolock) 2. 限制结果集的数据量,如使用TO ...

  6. SQL SERVER性能优化综述

    SQL SERVER性能优化综述 一个系统的性能的提高,不单单是试运行或者维护阶段的性能调优的任务,也不单单是开发阶段的事情,而是在整个软件生命周期都需要注意,进行有效工作才能达到的.所以我希望按照软 ...

  7. SQL Server 性能优化之RML Utilities:快速入门(Quick Start)(1)

      SQL Server 性能优化之RML Utilities:快速入门(Quick Start)(1) 安装Quick Start工具 RML(Replay Markup Language)是MS ...

  8. Oracle SQL语句性能优化方法大全

    Oracle SQL语句性能优化方法大全 下面列举一些工作中常常会碰到的Oracle的SQL语句优化方法: 1.SQL语句尽量用大写的: 因为oracle总是先解析SQL语句,把小写的字母转换成大写的 ...

  9. 【SQL Server性能优化】删除大量数据的方法比较

    原文:[SQL Server性能优化]删除大量数据的方法比较 如果你要删除表中的大量数据,这个大量一般是指删除大于10%的记录,那么如何删除,效率才会比较高呢? 而如何删除才会对系统的影响相对较小呢? ...

  10. 【SQL Server性能优化】运用SQL Server的全文检索来提高模糊匹配的效率

    原文:[SQL Server性能优化]运用SQL Server的全文检索来提高模糊匹配的效率 今天去面试,这个公司的业务需要模糊查询数据,之前他们通过mongodb来存储数据,但他们说会有丢数据的问题 ...

随机推荐

  1. arch Failed to load module "intel"

    arch启动x的时候出现问题困扰我一天了,终于解决掉了. 错误如下: [ 61.086] (II) LoadModule: "intel" [ 61.087] (WW) Warni ...

  2. linux下 文件IO 相关

    linux下操作文件或设备,需要一个文件描述符 file descriptor,fd 来引用.fd是一个非负整数,实际上是一个索引值,指向文件的记录表,对文件的操作都需要fd.默认的几个:标准输入流 ...

  3. 13、Cocos2dx 3.0游戏开发找小三之3.0中的Director :郝萌主,一统江湖

    重开发人员的劳动成果.转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27706967 游戏中的基本元素 在曾经文章中.我们具 ...

  4. codeforces 659C Tanya and Toys

    题目链接:http://codeforces.com/problemset/problem/659/C 题意: n是已经有的数字,m是可用的最大数字和 要求选自己没有的数字,且这些数字的数字和不能超过 ...

  5. JNI生成C的头文件

    最近再给android封装一个C语言的so,以供安卓程序下使用. 再次记录一下,防止以后忘记了. 首先下载安装JDK,下载地址:http://www.oracle.com/technetwork/ja ...

  6. CreateThread、_beginthreadex和AfxBeginThread 的区别

    CreateThread._beginthreadex和AfxBeginThread 创建线程好几个函数可以使用,可是它们有什么区别,适用于什么情况呢?参考了一些资料,写得都挺好的,这里做一些摘抄和整 ...

  7. make 2>&1 | tee log.txt之小析

    前言 接触过linux的人,或多或少都会了解一点make 2>&1 | tee log.txt这个命令. 1. make是什么? make是linux下一个非常强大的命令,简单点就是你要 ...

  8. Codeforces Round #246 (Div. 2) —B. Football Kit

    B. Football Kit time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  9. 杭州电ACM1098——Ignatius&#39;s puzzle

    这个话题.简单的数学. 对于函数,f(x)=5*x^13+13*x^5+k*a*x,输入k,对于休闲x,一个数字的存在a,使f(x)是65可分. 对于休闲x. 因此,当x = 1时间,f(x) = 1 ...

  10. webapi Task

    webapi+Task并行请求不同接口实例 标题的名称定义不知道是否准确,不过我想表达的意思就是使用Task特性来同时请求多个不同的接口,然后合并数据:我想这种场景的开发对于对接过其他公司接口的人不会 ...