网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.(原创)oracle数据库备份与恢复 a.
.关于Oracle 9i 跳跃式索引扫描(I.
.案例学习Oracle错误:ORA-00054.
.教你如何快速转移Oracle中海量数.
.Oracle10g中新的SQLoptimizerhin.
.如何使用户没有telnet和ftp权限.
.ORACLE 10g认证6月将正式登场.
.ORACLE中实现ASCII字符串和16进制.
.关于连接池.
.ORACLE应用中常见的傻瓜问题1000.
.ORA-12154: TNS: 无法解析指定的.
.您需要虚拟记忆体吗?.
.Oracle数据库中独一无二的Cache对.
.实用心得:虚拟机下Oracle的安装.
.如何从一个大tgz包中解压出某个文.
.关于自动PGA管理的进一步探讨.
.使用Oracle数据库高级复制中最简.
.ORACLE 应用经验(5)-表空间.
.解析Oracle各种数据类型.
.Application Server明细列表.

如何分析SQL语句

发表日期:2008-2-9



  很多时候,我们不太清楚自己写的SQL语句好还是不好,往往数据量一大,程序运行变慢。其实在SQL/PLUS里可以很清楚的分析出SQL语句的执行计划,它可以提醒我们来创建索引或改变SQL语句的写法。
  
    先在sys用户下运行@/Oracle_HOME/sqlplus/admin/plustrce.sql
  
  内容:
  set echo on
  drop role plustrace;
  create role plustrace;
  grant select on v_$sesstat to plustrace;
  grant select on v_$statname to plustrace;
  grant select on v_$session to plustrace;
  grant plustrace to dba with admin option;
  set echo off
  
  产生plustrace角色,然后在sys用户下把此角色赋予一般用户&username
  
  SQL> grant plustrace to &username;
  
    然后找到/ORACLE_HOME/rdbms/admin/utlXPlan.sql,然后在当前用户SQL>下运行,它创建一个plan_table,用来存储分析SQL语句的结果。
  
   create table PLAN_TABLE (
   statement_id  varchar2(30),
   timestamp    date,
   remarks     varchar2(80),
   operation    varchar2(30),
   options     varchar2(30),
   object_node   varchar2(128),
   object_owner  varchar2(30),
   object_name   varchar2(30),
   object_instance numeric,
   object_type   varchar2(30),
   optimizer    varchar2(255),
   search_columns number,
   id       numeric,
   parent_id    numeric,
   position    numeric,
   cost      numeric,
   cardinality   numeric,
   bytes      numeric,
   other_tag    varchar2(255),
   partition_start varchar2(255),
   partition_stop varchar2(255),
   partition_id  numeric,
   other      long,
   distribution  varchar2(30));
  
    在SQL/PLUS的窗口运行以下命令
  
  
   set time on; (说明:打开时间显示)
   set autotrace on; (说明:打开自动分析统计,并显示SQL语句的运行结果)
   set autotrace traceonly; (说明:打开自动分析统计,不显示SQL语句的运行结果)
  
    接下来你就运行测试SQL语句,看到其分析统计结果了。一般来讲,我们的SQL语句应该避免对大表的全表扫描。
  
    关闭以上功能,在SQL/PLUS的窗口运行以下命令
  
   set time off; (说明:关闭时间显示)
   set autotrace off; (说明:关闭自动分析统计)
上一篇:如何为oracle中的表增加像sql server一样的自动列 人气:701
下一篇:在Oracle9i Release 2中使用PL/SQL的集合增强 人气:577
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐