SQL语句优化,高效率SQL

来源:互联网 发布:双色球算法必中6红球 编辑:程序博客网 时间:2024/06/02 03:26

影响DBMS性能的因素:硬件和软件。
硬件调优:
* 1、使用频率高的CPU。
* 2、使用多处理器。
* 3、加大内存容量。
* 4、增加Cache缓存。
* 5、提高网络速度等。

企业必用的sql语句优化,手把手学习oracle数据库,一周轻松掌握并精通。提供免费的视频。
https://m.qlchat.com/topic/details?topicId=2000000204413360

SQL优化,主要是优化查询效率,查询有两种:
1、全表扫描检索,不管查询什么数据,都是全表依次扫描去查询,数据量大的话,会大大降低性能。
2、按照索引检索,根据索引去检索数据,速度会非常快。

SQL优化的手段
1、使用索引,在经常需要进行检索的字段上创建索引,可以大大的提供查询的效率,但是要注意合理的创建索引,因为索引虽然提高了查询效率,但是牺牲了其他方面的性能,比如:增加、删除、修改就会变慢,同时索引还会占据一定的存储空间,比如删除了记录,但索引是没被删除的,还会有一些索引碎片的问题,索引很好,但不要乱建。

2、避免在索引列上计算,避免在索引列上使用函数,避免在索引列上使用not,避免在索引列使用<>不等于,避免在索引列上使用is null,is not null,避免改变索引列的数据类型(比如索引列是字符类型,如果你用数字类型去和他比较,Oracle会把索引列的字符类型隐示的转换成数字类型去比较),避免在索引列上使用模糊查询(会导致检索访问过广),
否则不避免,就会破坏索引,而使用全表扫描的方式,降低效率。

3、使用预编译查询,尽量使用参数化SQL,既可以防止SQL注入又可以利用预编译的SQL,预编译的好处是编译一次,以后就不需要编译了,直接使用预编译好的SQL,节省了DBMS(数据库管理系统)去编译的时间。

4、使用数据库内部函数和被数据库优化的语句,比如max()、between and等。

5、使用大写编写SQL语句(DBMS在解析SQL语句时,会检查SQL语句,若不是大写,会全部转换成大写)。

6、使用别名(DBMS解析SQL语句时会给列取别名),我们自己给表取别名,给字段列取别名,这样可以减少DBMS解析的时间并减少列名引起的歧义错误。

7、减少访问数据库的次数,减少查询的次数,尽量把多条SQL语句压缩成一条SQL语句,把频繁访问数据库的方式改成使用批处理。

8、避免使用”“,select 是一个非常低效的方法,DBMS在解析SQL语句的过程中会去数据字典表里查询该表对应的字段列,并依次按照顺序把 “* ” 转换成所有的列名,将消耗很多时间。

9、避免使用消耗资源的操作,带有distinct、union、minus、intersect、order by的SQL语句会启动SQL引擎,执行消耗资源的排序功能,distinct需要一次排序操作,其他的至少需要2次排序操作。

10、用where语句替换having语句,having语句只会在查询出所有记录后才对数据进行过滤,一般用于分组后,对分组的结果进行过滤,除此外,应该尽量在查询出记录之前通过where进行数据过滤。

11、用in、union来代替or。or的效率极低。

12、用union all来代替union,union会合并重复的数据,并排序,union all 不会合并重复的数据,不会排序。

13、exists来代替in,not exists 代替not in,in会对他里面的子查询进行排序及合并操作。

14、用关联查询(连表查询)来代替exists子查询,关联查询一般比子查询效率高。

15、用truncate来代替delete。delete是dml语句删除的内容,删除掉的数据可以通过rollback回滚回来,而truncate table 表名,是ddl语句删除的内容无法通过rollback回滚回来,truncate截断的意思。
delete语句DBMS会把刚刚操作的数据,保存到回滚段,并保存到commit后才能被清理掉。而truncate无需做这个工作,故效率要高很多。

16、exists来代替distinct、group by来代替distinct。

17、用>=代替>,<=代替<,比如deptno>3,应写成deptno>=4,前者DBMS要先定位到3的记录,并且向前扫描>3的记录,而后者直接定位到4,速度快很多。

18、用between and 代替<=,>=,因为between and是数据库优化的语句。

19、优化group by语句,把不需要分组的数据,提前通过where过滤掉。

20、优化where语句,把能过滤掉大量数据的条件放在where语句中靠前的位置,明确的过滤条件也应尽量放在靠前的位置,不明确的模糊查询的条件放在最后。

21、关联表查询时,把记录数较少的表,放在from子句中的右边,因为DBMS解析SQL时是从右到左的顺序,靠右边的表或结果集优先被处理。

22、在程序中尽量多的使用commit,这样程序的性能会得到提高,需求也会因为commit所释放的资源而减少,commit释放的资源:
1、回滚段上用于恢复的数据信息。
2、被程序语句获得的锁资源。
3、redo log buffer中的空间
4、Oracle为了管理上述3种资源的内部花费。

学习推荐:
企业必用的sql语句优化,手把手学习oracle数据库,一周轻松掌握并精通。提供免费的视频。
https://m.qlchat.com/topic/details?topicId=2000000204413360

原创粉丝点击