一、Oracle SqlPlus设置Login.sql的技巧
--sqlplus默认编辑器设置为vi
define _editor=vi
--设置显示“已选择xx行”,显示本次sql命令处理的记录条数,缺省为on
set feedback on
--默认打开dbma_output,这样不必要每次在输入这个命令,同时将默认缓冲池设置得尽可能大去除重定向(spool)输出每行的拖尾空格,缺省为off
set timing on
--说明:显示sql语句的运行时间。默认值为off。
--在sqlplus中使用,时间精确到0.01秒。也就是10毫秒。
--在pl/sql developer 中,时间精确到0.001秒:
set timing on
--去除标准输出每行的拖尾空格,缺省为off
set trimout on
--去除重定向(spool)输出每行的拖尾空格,缺省为off
set trimspool on
col NAME format a20
--默认地打开dbms_output(这样就不必每次再键入这个命令了)。另外也将默认缓冲区大小设置得尽可能大。
set serveroutput on size 1000000
--假脱机输出文本时,会去除文本行两端的空格,而且行宽不定,如果设置为off(默认设置),假脱机输出的文本行宽度则等于所设置的linesize
set trimspool on
--设置选择long和clob列时显示的默认字节数
set long 5000
--设置显示的文本宽为200个字符
set linesize 200
--设置sqlplus多久打印一次标题,将此参数设置大些这样每页只显示一次标题
set pagesize 9999
--设置autotrace得到解释计划输出的默认宽度,一般80足够放下整个计划
column plan_plus_exp format a80
--设置sqlplus提示符,显示格式为用户@数据库名
column global_name new_value gname
define gname=idlecolumn global_name new_value gnameselect lower(user) ||'@'|| substr(global_name,1,decode(dot,0,length(global_name),dot-1)) global_namefrom (select global_name,instr(global_name,'.') dot from global_name);set sqlprompt '&gname>'
补充重要属性
--a是固定写法,20表示占用20个字符。格式化列名显示
col NAME format a20
使用scott用户登录后如下
[oracle@RHEL65 ~]$ sqlplus scott/oracle
SQL*Plus: Release 11.2.0.1.0 Production on Sat Jan 23 00:11:26 2016
Copyright (c) 1982, 2009, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
scott@ORCL>select * from emp;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
7369 SMITH CLERK 7902 1980-12-17 00:00:00 800 20
7499 ALLEN SALESMAN 7698 1981-02-20 00:00:00 1600 300 30
7521 WARD SALESMAN 7698 1981-02-22 00:00:00 1250 500 30
7566 JONES MANAGER 7839 1981-04-02 00:00:00 2975 20
7654 MARTIN SALESMAN 7698 1981-09-28 00:00:00 1250 1400 30
7698 BLAKE MANAGER 7839 1981-05-01 00:00:00 2850 30
7782 CLARK MANAGER 7839 1981-06-09 00:00:00 2450 10
7788 SCOTT ANALYST 7566 1987-04-19 00:00:00 3000 20
7839 KING PRESIDENT 1981-11-17 00:00:00 5000 10
7844 TURNER SALESMAN 7698 1981-09-08 00:00:00 1500 0 30
7876 ADAMS CLERK 7788 1987-05-23 00:00:00 1100 20
7900 JAMES CLERK 7698 1981-12-03 00:00:00 950 30
7902 FORD ANALYST 7566 1981-12-03 00:00:00 3000 20
7934 MILLER CLERK 7782 1982-01-23 00:00:00 1300 10
14 rows selected.
scott@ORCL>set autot trace exp stat;
scott@ORCL>select * from emp;
14 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 3956160932
--------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 14 | 532 | 3 (0)| 00:00:01 |
| 1 | TABLE ACCESS FULL| EMP | 14 | 532 | 3 (0)| 00:00:01 |
--------------------------------------------------------------------------
Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
8 consistent gets
0 physical reads
0 redo size
1630 bytes sent via SQL*Net to client
524 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
14 rows processed
scott@ORCL>
转载自:http://www.jb51.net/article/78543.htm
其他资料:a. https://blog.csdn.net/robbie1314520/article/details/7388245
二、Windows cmd命令行设置默认属性失效
测试发现,不同的快捷方式下设置不同的默认值,启动命令命令行默认属性不同。
记得当时花了一段时间,由cmd运行启动的命令行屏幕缓冲设置9000多,但是通过桌面快捷方式启动cmd,还是原来的默认属性。这样也会一定程度上导致,sqlplus的login.sql设置的参数失效。
可能是:
修改所有者 ---> 修改user,system用户对cmd的管理修改权限。

三、SQL工具有个可是把SQL代码格式化那个在哪里啊
上面的工具栏 Tools ---> PL/SQL beautifier
本文介绍了如何通过设置SQLPlus的Login.sql脚本来优化输出格式,包括调整输出宽度、显示行数反馈等,并解决了在不同启动方式下设置可能失效的问题。
1556

被折叠的 条评论
为什么被折叠?



