我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ORACLE抓低效的SQL语句

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ORACLE抓低效的SQL语句

ORACLE抓低效的SQL语句

转载 ORACLE_FANS 发布于2013-01-19 00:59:14 阅读数 1996 收藏 展开     信息系统访问量又不大,瓶颈一般不会出现在应用层,极有可能在数据库这一层,不用急着看程序。先找出逻辑读取次数最多的SQL,硬盘读取次数最多的SQL,找到SQL,对于SQL进行优化。看看有没有发生全表扫描的地方。
一般发生全表扫描,极有可能是没有建立合理的索引,或者索引由于左边引用函数或其它原因造成索引失效。
对于运行一年多的系统,最好要自己写一个自动重建索引的程序,定时重建索引。
或者使用TOAD工具帮你重建索引。

另外在看一下数据库的CPU占用率,如果占用率在经常在80%-100%,那一定要是SQL或存储过程及trigger中写的不好。

不需要从应用层找SQL,方向性错误,太累,也看不出效果。
而应当使用pl/SQL, toad等工具,分析出最bad的SQL语句,一看到这些语句后,再修改应用层的查询就是了。又快又方便。



-- 逻辑读多的SQL
select * from (select buffer_gets, sql_text
from v$sqlarea
where buffer_gets > 500000
order by buffer_gets desc) where rownum<=30;

-- 执行次数多的SQL   
  select sql_text,executions from
  (select sql_text,executions from v$sqlarea order by executions desc)
   where rownum<81;

-- 读硬盘多的SQL 
  select sql_text,disk_reads from
  (select sql_text,disk_reads from v$sqlarea order by disk_reads desc)
   where rownum<21;    

-- 排序多的SQL   
  select sql_text,sorts from
   (select sql_text,sorts from v$sqlarea order by sorts desc)
    where rownum<21;           
 
--分析的次数太多,执行的次数太少,要用绑变量的方法来写sql
set pagesize 600;
set linesize 120;
select substr(sql_text,1,80) "sql", count(*), sum(executions) "totexecs"
   from v$sqlarea
   where executions < 5
   group by substr(sql_text,1,80)
   having count(*) > 30
   order by 2;

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ORACLE抓低效的SQL语句

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ORACLE抓低效的SQL语句

ORACLE抓低效的SQL语句 转载 ORACLE_FANS 发布于2013-01-19 00:59:14 阅读数 1996 收藏 展开     信息系统访问量又不大,瓶
2016-05-09

mysql怎么查找效率低的SQL语句

本篇内容主要讲解“mysql怎么查找效率低的SQL语句”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql怎么查找效率低的SQL语句”吧!MySQL通过慢查询日志定位那些执行效率较低的SQL
2023-06-01

oracle常用SQL语句

+ ",(select LISTAGG(mo.model_code,",") within group(order by mo.model_code) from srm_pos_resource_model mo where mo.supplier_id=t.
oracle常用SQL语句
2014-10-15

oracle用的是sql语句吗

是的,oracle使用sql语句。sql(结构化查询语言)是oracle主要的数据操作语言,用于创建和管理数据库对象,检索和更新数据,以及执行复杂的数据操作和查询。oracle支持广泛的sql语句类型,包括数据定义语言、数据操作语言、数据控
oracle用的是sql语句吗
2024-04-19

ORACLE查询当前执行效率低的sql

--CPU高的SQL select sql_text from v$sql order by cpu_time desc --逻辑读多的SQL: select * from (select buffer_gets, sql_text from v$sqlare
2019-07-14

oracle怎么写sql语句

编写 oracle sql 语句需要遵循以下步骤:1. 连接到数据库;2. 选择要检索的列;3. 指定条件(可选);4. 对结果进行排序(可选);5. 限制结果数量(可选);6. 使用聚合函数(可选);7. 使用子查询(可选);8. 使用连
oracle怎么写sql语句
2024-04-19

[转] Oracle sql语句执行顺序

sql语法的分析是从右到左一、sql语句的执行步骤:1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义。2)语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限。3)视图转换,将涉及视图的查询语句转换为相应的对基表查询语句。4)
[转] Oracle sql语句执行顺序
2015-06-02

编程热搜

目录