search
HomeDatabaseMysql TutorialOracle 性能优化
Oracle 性能优化Jun 07, 2016 pm 03:38 PM
oracleselectoptimizationuseperformancestatementavoid

1、在select语句中避免使用 “*” 2、尽可能减小记录集行数 限制记录集获取到的记录行数同样可以缩短语句执行时间,提高查询效率。 SELECT USER_NAME, ADDRESS, LOGIN_ADTE FROM LOG_EVENT WHERE ROWNUM = 100 ORDER BY LOGON_DATE DESC; 3、使用ROWID 高效

1、在select语句中避免使用 “*”

2、尽可能减小记录集行数

         限制记录集获取到的记录行数同样可以缩短语句执行时间,提高查询效率。

         SELECT USER_NAME, ADDRESS, LOGIN_ADTE

FROM LOG_EVENT

WHERE ROWNUM

3、使用ROWID 高效删除重复数据

         在重复的记录中,可能所有列的内容都相同,但是ROWID 不会重复。

         DELETE FROM STU S

WHERE S.ROWID > (SELECT MIN(T.ROWID)

FROM STU T

WHERE T.SNO = S.SNO);

4、使用TRUNCATE 替代DELETE删除记录

5、高效统计记录行数(实际应用中并没有使用价值)

         使用USER_TABLES 视图查询记录行数

         SELECT TABLE_NAME, NUM_ROWS

         FROM USER_TABLES

         WHERE TABLE_NAME = ‘STU’

         补充:USER_TABLES 视图中保存了Oracle的所有用户表基本信息,包括表空间、状态、缓存等。

6、尽量多使用COMMIT

         执行COMMIT 语句后能释放的资源主要包括:

l  回滚段上用于回复数据的信息

l  被程序语句获取的锁

l  REDO LOG BUFFER 中的空间

l  Oracle 为管理上述3 种资源的内部花销

7、避免使用HAVING 语句

         HAVING 语句只会在检索出所有记录之后才对结果集进行过滤。若能通过WHERE 子句限制查询的数目,可以减少这方面的开销。

8、用EXISTS 替代IN 谓词

         带有EXISTS 谓词的子查询不返回任何实际数据,只产生逻辑真值TRUE 或逻辑假值FALSE。

9、使用 “>=” 代替 “>” 运算符

10、避免在SELECT 子句中使用DISTINCT 关键字

         补充:消除重复记录可以通过子查询、GROUPBY 等其他方式实现,对于大数据来说,尽量避免使用DISTINCT。

11、用索引提高查询效率

12、避免在索引列上进行运算

         在索引列上进行运算,将导致索引失效。

13、在索引列上使用UNION替代OR

         在SELECT 语句中对索引列进行OR操作,此时索引将不会被引用。对索引列使用OR 运算符将造成全表扫描。

         补充:使用UNION 代替OR 操作规则只针对多个索引列有效,如果有的列没有索引,检索效率可能反而会因为没有选择OR 而降低。

14、避免在索引列上使用ISNULL 或 IS NOT NULL 条件

         对于Oracle 索引来说,如果一个索引列的某个值为空,该值将不存在于索引列中。

15、使用WHERE 子句优化GROUP BY (内容同7)

         使用WHERE 子句实现部分HAVING 子句的功能。

16、处理预定义异常

 

17、处理自定义异常

 

本内容摘自《Oracle 数据库编程经典300例》

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
oracle怎么查询所有索引oracle怎么查询所有索引May 13, 2022 pm 05:23 PM

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

什么是oracle asm什么是oracle asmApr 18, 2022 pm 04:16 PM

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

oracle全角怎么转半角oracle全角怎么转半角May 13, 2022 pm 03:21 PM

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

Oracle怎么查询端口号Oracle怎么查询端口号May 13, 2022 am 10:10 AM

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

oracle怎么删除sequenceoracle怎么删除sequenceMay 13, 2022 pm 03:35 PM

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

oracle怎么查询数据类型oracle怎么查询数据类型May 13, 2022 pm 04:19 PM

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

oracle查询怎么不区分大小写oracle查询怎么不区分大小写May 10, 2022 pm 05:45 PM

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

Oracle怎么修改sessionOracle怎么修改sessionMay 13, 2022 pm 05:06 PM

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.