login.sql注释autotrace以及退格修改

1.login.sql释义 

ThomasKyte的login.sql设置如下

  
  
  
  
  1. define _editor=vim    --设置sqlplus 默认编辑器  
  2. set serveroutput on size 1000000  --打开dbms-out 设置缓冲区尽量大  
  3. set trimspool on    --设置脱机输出文本时,取出文本行两端的空格而且行宽不定  
  4. set long 5000   --设置选择LONG和colb列时默认字节数  
  5. set linesize 150  --设置sqlplus默认显示文本行宽为150字符  
  6. set pagesize 9999  --设置sqlplus多久打印一次标题,尽量大,以便每页答应一个标题  
  7. column plan_plus_exp format a80 --设置由autotrace得到的解释计划输出宽度.a80可以显示整个计划  
  8. column global_name new_value gname  
  9. set termout off  
  10. define gname=idle  
  11. column global_name new_value gname  
  12. select lower(user) || '@' || substr( global_name, 1, 
  13. decode( dot, 0, length(global_name), dot-1) ) global_name 
  14. from (select global_name, instr(global_name,'.') dot from global_name ); 
  15. set sqlprompt '&gname>'  
  16. set termout on  

 

define gname=idle 

column global_name new_value gname 

select lower(user) || '@' || substr( global_name, 1,

decode( dot, 0, length(global_name), dot-1) ) global_name

from (select global_name, instr(global_name,'.') dot from global_name );

column global_name new_value gname  告诉sqlplus取得一个新的global_name列的最后一个值,并且将值赋给gname,然后选出global_name,并且与登录名相连接

这样得到的sqlplus提示符如下

 

  
  
  
  
  1. [oracle@stark ~]$ sqlplus scott/*** 
  2.  
  3. SQL*Plus: Release 10.2.0.4.0 - Production on Thu Jul 12 23:27:06 2012 
  4.  
  5. Copyright (c) 1982, 2007, Oracle.  All Rights Reserved. 
  6.  
  7.  
  8. Connected to
  9. Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit Production 
  10. With the Partitioning, OLAP, Data Mining and Real Application Testing options 
  11.  
  12. scott@STARK> 

 2.autotrace释义

autotrace是sqlplus的一个工具可以现实执行计划(explain plan)以及所用的资源,对于以后的工作有很大的作用,autotrace的配置方式不止一种.一下是比较流行的一种.

以sys登录数据库,执行$ORACLE_HOME/rdbms/admin下面的utlxplan

  
  
  
  
  1. sys@STARK>@/oracle/10.2/rdbms/admin/utlxplan.sql ; 
  2.  
  3. Table created. 

之后授权执行以下语句

 

 

  
  
  
  
  1. sys@STARK>grant all on PLAN_TABLE  to sys; 
  2.  
  3. Grant succeeded. 

如果想要所有用户都可以使用autotrace只需要将username更改为public就可以

以后只要执行sqldml语句(select,delete,update,megre,inster)就会生成报告.

他对于监视和调优这些语句很有帮助.

控制报告

set autotrace off     --不生成报告,默认

set autotrace on     --生成执行报告,包括执行路径和统计信息,同时返回执行结果

set autotrace on explain     --只显示执行路径

set autotrace on statistics     --只显示统计信息

set autotrace traceonly     --与set autotrace on的区别是不显示执行结果

 

 eg

 

  
  
  
  
  1. sys@STARK>set autotrace off
  2. sys@STARK>select count(*) from tab; 
  3.  
  4.   COUNT(*) 
  5. ---------- 
  6.       3670 
  7.  
  8. sys@STARK>set autotrace on
  9. sys@STARK>select count(*) from tab; 
  10.  
  11.   COUNT(*) 
  12. ---------- 
  13.       3670 
  14.  
  15.  
  16. Execution Plan 
  17. ---------------------------------------------------------- 
  18. Plan hash value: 3662916347 
  19.  
  20. --------------------------------------------------------------------------------- 
  21. | Id  | Operation              | Name   | Rows  | Bytes | Cost (%CPU)| Time     | 
  22. --------------------------------------------------------------------------------- 
  23. |   0 | SELECT STATEMENT       |        |     1 |    77 |   119   (1)| 00:00:02 | 
  24. |   1 |  SORT AGGREGATE        |        |     1 |    77 |            |          | 
  25. |   2 |   NESTED LOOPS OUTER   |        |   997 | 76769 |   119   (1)| 00:00:02 | 
  26. |*  3 |    TABLE ACCESS FULL   | OBJ$   |   997 | 72781 |    32   (4)| 00:00:01 | 
  27. |   4 |    TABLE ACCESS CLUSTER| TAB$   |     1 |     4 |     1   (0)| 00:00:01 | 
  28. |*  5 |     INDEX UNIQUE SCAN  | I_OBJ# |     1 |       |     0   (0)| 00:00:01 | 
  29. --------------------------------------------------------------------------------- 
  30.  
  31. Predicate Information (identified by operation id): 
  32. --------------------------------------------------- 
  33.  
  34.    3 - filter("O"."TYPE#"<=5 AND "O"."OWNER#"=USERENV('SCHEMAID'AND 
  35.               "O"."TYPE#">=2 AND "O"."LINKNAME" IS NULL
  36.    5 - access("O"."OBJ#"="T"."OBJ#"(+)) 
  37.  
  38.  
  39. Statistics 
  40. ---------------------------------------------------------- 
  41.           0  recursive calls 
  42.           0  db block gets 
  43.        8382  consistent gets 
  44.           0  physical reads 
  45.           0  redo size 
  46.         516  bytes sent via SQL*Net to client 
  47.         492  bytes received via SQL*Net from client 
  48.           2  SQL*Net roundtrips to/from client 
  49.           0  sorts (memory) 
  50.           0  sorts (disk) 
  51.           1  rows processed 
  52. sys@STARK>select count(*) from tab; 
  53.  
  54.   COUNT(*) 
  55. ---------- 
  56.       3670 
  57.  
  58.  
  59. Execution Plan 
  60. ---------------------------------------------------------- 
  61. Plan hash value: 3662916347 
  62.  
  63. --------------------------------------------------------------------------------- 
  64. | Id  | Operation              | Name   | Rows  | Bytes | Cost (%CPU)| Time     | 
  65. --------------------------------------------------------------------------------- 
  66. |   0 | SELECT STATEMENT       |        |     1 |    77 |   119   (1)| 00:00:02 | 
  67. |   1 |  SORT AGGREGATE        |        |     1 |    77 |            |          | 
  68. |   2 |   NESTED LOOPS OUTER   |        |   997 | 76769 |   119   (1)| 00:00:02 | 
  69. |*  3 |    TABLE ACCESS FULL   | OBJ$   |   997 | 72781 |    32   (4)| 00:00:01 | 
  70. |   4 |    TABLE ACCESS CLUSTER| TAB$   |     1 |     4 |     1   (0)| 00:00:01 | 
  71. |*  5 |     INDEX UNIQUE SCAN  | I_OBJ# |     1 |       |     0   (0)| 00:00:01 | 
  72. --------------------------------------------------------------------------------- 
  73.  
  74. Predicate Information (identified by operation id): 
  75. --------------------------------------------------- 
  76.  
  77.    3 - filter("O"."TYPE#"<=5 AND "O"."OWNER#"=USERENV('SCHEMAID'AND 
  78.               "O"."TYPE#">=2 AND "O"."LINKNAME" IS NULL
  79.    5 - access("O"."OBJ#"="T"."OBJ#"(+)) 
  80.  
  81. sys@STARK>select count(*) from tab; 
  82.  
  83.   COUNT(*) 
  84. ---------- 
  85.       3670 
  86.  
  87.  
  88. Statistics 
  89. ---------------------------------------------------------- 
  90.           0  recursive calls 
  91.           0  db block gets 
  92.        8382  consistent gets 
  93.           0  physical reads 
  94.           0  redo size 
  95.         516  bytes sent via SQL*Net to client 
  96.         492  bytes received via SQL*Net from client 
  97.           2  SQL*Net roundtrips to/from client 
  98.           0  sorts (memory) 
  99.           0  sorts (disk) 
  100.           1  rows processed 
  101. sys@STARK>set autotrace traceonly 
  102. sys@STARK>select count(*) from tab; 
  103.  
  104.  
  105. Execution Plan 
  106. ---------------------------------------------------------- 
  107. Plan hash value: 3662916347 
  108.  
  109. --------------------------------------------------------------------------------- 
  110. | Id  | Operation              | Name   | Rows  | Bytes | Cost (%CPU)| Time     | 
  111. --------------------------------------------------------------------------------- 
  112. |   0 | SELECT STATEMENT       |        |     1 |    77 |   119   (1)| 00:00:02 | 
  113. |   1 |  SORT AGGREGATE        |        |     1 |    77 |            |          | 
  114. |   2 |   NESTED LOOPS OUTER   |        |   997 | 76769 |   119   (1)| 00:00:02 | 
  115. |*  3 |    TABLE ACCESS FULL   | OBJ$   |   997 | 72781 |    32   (4)| 00:00:01 | 
  116. |   4 |    TABLE ACCESS CLUSTER| TAB$   |     1 |     4 |     1   (0)| 00:00:01 | 
  117. |*  5 |     INDEX UNIQUE SCAN  | I_OBJ# |     1 |       |     0   (0)| 00:00:01 | 
  118. --------------------------------------------------------------------------------- 
  119.  
  120. Predicate Information (identified by operation id): 
  121. --------------------------------------------------- 
  122.  
  123.    3 - filter("O"."TYPE#"<=5 AND "O"."OWNER#"=USERENV('SCHEMAID'AND 
  124.               "O"."TYPE#">=2 AND "O"."LINKNAME" IS NULL
  125.    5 - access("O"."OBJ#"="T"."OBJ#"(+)) 
  126.  
  127.  
  128. Statistics 
  129. ---------------------------------------------------------- 
  130.           0  recursive calls 
  131.           0  db block gets 
  132.        8382  consistent gets 
  133.           0  physical reads 
  134.           0  redo size 
  135.         516  bytes sent via SQL*Net to client 
  136.         492  bytes received via SQL*Net from client 
  137.           2  SQL*Net roundtrips to/from client 
  138.           0  sorts (memory) 
  139.           0  sorts (disk) 
  140.           1  rows processed 

 设定退格

 

 

设定环境变量:

 

1)在bash下,把 stty erase ^H 添加到.bash_profile中

 

2)在csh下,把 stty erase ^H 添加到.cshrc中

 

下面是我今天的实现方法(在bash下)

 

[root@testdb ~]# su - oracle   进入oracle主目录,里面有 .bash_profile

[root@testdb ~]# vi .bash_profile 添加一行

 

stty erase ^H

 

:wq 保存退出

 

重新用oracle登录则可。

本文出自 “望月飞鱼” 博客,转载请与作者联系!

你可能感兴趣的:(autotrace,loginsql)