Chinaunix首页 | 论坛 | 博客
  • 博客访问: 159061
  • 博文数量: 40
  • 博客积分: 1746
  • 博客等级: 上尉
  • 技术积分: 340
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-29 15:57
文章分类

全部博文(40)

文章存档

2011年(23)

2010年(17)

我的朋友

分类: Oracle

2010-11-12 12:25:08

一般使用SQL PLUS导出数据时一般使用以下参数就可以了。

set echo off; -- 不显示脚本中的每个sql命令(缺省为on)
set feedback off; -- 禁止回显sql命令处理的记录条数(缺省为on)
set heading off; -- 禁止输出标题(缺省为on)
set pagesize 0; -- 禁止分页输出
set linesize 1000; -- 设置每行的字符输出个数为1000,放置换行(缺省为80 )
set numwidth 16; -- 设置number类型字段长度为16(缺省为10)
set termout off; -- 禁止显示脚本中命令的执行结果(缺省为on)
set trimout on; -- 去除标准输出每行的行尾空格(缺省为off)
set trimspool on; -- 去除spool输出结果中每行的结尾空格(缺省为off) 

sqlplus 维护系统变量(也称set变量)利用它可为sqlplus交互建立一个特殊的环境 如:设置number数据的显示宽度 设置每页的行数 设置列的宽度等。可用set命令改变这些系统变量也可用show命令列出它们.

 

以下是全部的用法

 使用set命令的语法如下:
   set 系统变量值

 其中系统变量及其可选值如下:
   arraysize          {20(默认值)|n}
   autocommit         {off(默认值)|on|immediate} 
   blockterminator    {.(默认值)|c}
   cmdsep             { |c|off(默认值)|on}
   compatibility      {v5|v6|v7|native(默认值)}
   concat             {.(默认值)|c|off|on(默认值)}
   copycommit         {0(默认值)|n}
   crt crt              
   define             {& |c|off|on(默认值)}
   echo               {off|on}
   embedded           {off(默认值)|on}
   escape             {\(默认值)|c|off(默认值)|on}
   feedback           {6(默认值)|n|off|on}
   flush              {off|on(默认值)}
   heading            {off|on(默认值)}
   headsep            {|(默认值)|c|off|on(默认值)}
   linesize           {80(默认值)|n}
   long               {80(默认值)|n}
   longchunksize      {80(默认值)|n}
   maxdata            n
   newpage            {1(默认值)|n}
   null text
   numformat          格式
   numwidth           {10(默认值)|n}
   pagesize           {14(默认值)|n}
   pause              {off(默认值)|on|text}
   recsep             {wrapped(默认值)|each|off}
   recsepchar         { |c}
   scan               {off|on(默认值)} 
   serveroutput       {off|on} size n
   showmode           {off(默认值)|on}
   space              {1(默认值)|n}
   sqlcase            {mixed(默认值)|lower|upper}
   sqlcontinue        {>  (默认值)|文本}
   sqlnumber          {off|on(默认值)}
   sqlperfix          {#(默认值)|c}
   sqlprompt          {sql>  (默认值)|文本}
   sqlterminator      { (默认值)|c|off|on(默认值)}
   suffix             {sql(默认值)|文本}
   tab                {off|on(默认值)}
   termout            {off|on(默认值)}
   time               {off(默认值)|on}
   timing             {off(默认值)|on}
   trimout            {off|on(默认值)}
   underline          {-(默认值)|c|off|on(默认值)}
   verify             {off|on(默认值)}
   wrap               {off|on(默认值)}

 系统变量说明:
   arraysize {20(默认值)|n} 置一批的行数,是sqlplus一次从数据库获取的行数,有效值为1至5000。大的值可提高查询和子查询的有效性,可获取许多行,但也需要更多的内存。当超过1000时,其效果不大。

   autocommit {off(默认值)|on|immediate} 控制oracle对数据库的修改的提交. 置on时,在oracle 执行每个sql命令或pl/sql块后对数据库提交修改;置off时则制止自动提交,需要手工地提交修改。例如用sql的commit命令,immediate功能同on。

   blockterminator {.(默认值)|c} 置非字母数字字符,用于结束pl/sql块。要执行块时必须发出run命令或/命令.

   cmdsep { |c|off(默认值)|on} 置非字母数字字符,用于分隔在一行中输入的多个 sql/plus命令。on或off控制在一行中是否能输入多个命令。on时将自动地将命令分隔符设为分号(其中c表示所置字符)。

   compatibility {v5|v6|v7|native(默认值)} 指定当前所链接的oracle版本。如果当前oracle的版本为5,则置compatibility为v5,为版本6时置成v6,为版本7时置成v7。如果希望由数据库决定该设置,则置成native。

   concat {.(默认值)|c|off|on(默认值)}设置结束一替换变量引用的字符。在中止替换变量引用字符之后可跟所有字符作为体会组成部分,否则sqlplus将解释为替换变量名的一部分。当concat开关为on时,sqlplus 可重置concat的值为点(.)。

   copycommit {0(默认值)|n} 控制copy命令提交对数据库修改的批数。每次拷贝n批后将提交到目标数据库。有效值为0到5000。可用变量arraysize设置一批的大小。如果置copycommit为0,则仅在copy操作结束时执行一次提交。

   crt crt  改变sqlplus runform命令使用的缺省crt文件。如果置crt不包含什么,则crt仅包含' ' ' ' 。如果在一个form的系统调用期间要使用new.crt(缺省crt是old.crt)。可按下列形式调用form:
     sql>  runform -c new form名
     或者
     sql>  set crt new
     sql>  runform form名
   第二中方法存储crt选择 以致在下次运行runform命令(是在同一次sqlplus交互中)时,不需要指定。

   define {& |c|off|on(默认值)} 设置在替换变量时所使用的字符。on 或 off 控制 sqlplus 是否扫描替换变量的命令及用他们的值代替。define 的 on 或 off 的设置控制scan 变量的设置。

   echo {off|on} 控制start命令是否列出命令文件中的每一命令。为on时,列出命令;为off时,制止列清单。

   embedded {off(默认值)|on} 控制每一报表在一页中开始的地方。为off时,迫使每一报表是在新页的顶部开始;为on时,运行一报表在一页的任何位置开始。
   
   escape {\(默认值)|c|off(默认值)|on} 定义作为escape字符的字符。为off时,使escape字符不起作用;为on时,使escape字符起作用。

   feedback {6(默认值)|n|off|on} 显示由查询返回的记录数。on和off置显示为开或关。置feedback为on时,等价于置n为1;如果置feedback为0 等价于将它置成off。

   flush {off|on(默认值)} 控制输出送至用户的显示设备。为off时,运行操作系统做缓冲区输出;为on时,不允许缓冲。仅当非交互方式运行命令文件时使用off 这样可减少程序i/o总数,从而改进性能。

   heading {off|on(默认值)} 控制报表中列标题的打印。为on时,在报表中打印列标题;为off时,禁止打印列标题。

   headsep {|(默认值)|c|off|on(默认值)} 定义标题分隔字符。可在column命令中使用标题分隔符,将列标题分成多行。on和off将标题分隔置成开或关。当标题分隔为关(off)时,sqlplus打印标题分隔符像任何字符一样。

   linesize {80(默认值)|n} 置sqlplus在一行中显示的字符总数,它还控制在ttitle和btitle中对准中心的文本和右对齐文本。可定义linesize为1至最大值,其最大值依赖于操作系统。

   long {80(默认值)|n} 为显示和拷贝long类型值的最大宽度的设置。对于oracle7,n的最大值为2g字节;对于版本6,最大值为32767。

   longchunksize {80(默认值)|n} 为sqlplus检索long类型值的增量大小。由于内存的限制,可按增量检索,该变量仅应用于oracle7。
   
   maxdata n  置sqlplus可处理的最大行宽字符数,其缺省值和最大值在不同操作系统中是可变的。

   newpage {1(默认值)|n} 置每一页的头和顶部标题之间要打印的空行数。如果为0,在页之间送一换号符,并在许多终端上清屏。
   
   null text 设置表示空值(null)的文本。如果null没有文本,则显示空格(缺省时)。使用column命令中的null子句可控制null变量对该列的设置。

   numformat 格式  设置显示数值的缺省格式,该格式是数值格式。
   
   numwidth {10(默认值)|n} 对显示数值设置缺省宽度。
   
   pagesize {14(默认值)|n} 置从顶部标题至页结束之间的行数。在11英寸长的纸上打印报表,其值为54,上下各留一英寸(newpage值为6)。

   pause {off(默认值)|on|text} 在显示报表时,控制终端滚动。在每一暂停时,必须按return键。on将引起sqlplus在每一报表输出页开始时暂停。所指定的文本是每一次sqlplus暂停时显示的文本。如果要键入多个词,必须用单引号将文本括起来。
   
   recsep {wrapped(默认值)|each|off} 
recsep告诉sqlplus在哪儿做记录分隔。例如将recsep置成wrapped,在每一缠绕行之后,打印记录分行符;如果将recsep置成each,sqlplus在每一行后打印一记录分行符;如果将recsep置成off,sqlplus不打印分行符。

   recsepchar { |c}  指定显示或打印记录分行符的条件。一个记录分行符,是由recsepchar指定的字符组成的单行。空格为recsepchar的默认字符。
   
   scan {off|on(默认值)} 控制对存在的替换变量和值的扫描。off禁止替换变量和值的处理;on则允许正常处理。
   
   serveroutput {off|on} size n 控制在sqlplus中的存储过程是否显示输出。off时为禁止;on时则显示输出。size设置缓冲输出的字节数,缺省值为2000。n不能小于2000或大于一百万。
   
   showmode {off(默认值)|on} 控制sqlplus在执行set命令时是否列出其新老值old或new的设置。

   space {1(默认值)|n}  设置输出列之间空格的数目,其最大值为10。
   
   sqlcase {mixed(默认值)|lower|upper}  先于执行之前,将sql命令和pl/sql块的大小写进行转换。sqlplus将转换命令中的全部文本,包括带引号的直接量和标示符。sqlcase不改变sql缓冲区本身。
   
   sqlcontinue {>  (默认值)|文本}  在一附加行上继续一sqlplus命令时,sqlplus以该设置的字符序列进行提示。
   
   sqlnumber {off|on(默认值)}  为sql命令和pl/sql块的第二行和后继行设置提示。为on时,提示行号;为off时,提示设置为sqlprompt的值。
   
   sqlperfix  {#(默认值)|c}  设置sqlplus前缀字符。在键入一sql命令或pl/sql块时,可在单独行上键入一sqlplus命令,由sqlplus的前缀字符做前缀。sqlplus直接执行该命令,不影响sql命令或pl/sql块。前缀字符必须是非字母数字字符。
   
   sqlprompt {sql>  (默认值)|文本}  设置sqlplus的命令提示符。
   
   sqlterminator { (默认值)|c|off|on(默认值)}  设置用于结束和执行sql命令的字符。off意味着sqlplus不识别命令终止符,用键入空行来结束sql命令;on重设置终止符为默认的分号。
   
   suffix {sql(默认值)|文本}  设置缺省文件的后缀。sqlplus在命令中使用,来引用命令文件。suffix不控制输出(spool)文件的扩展名。
   
   tab {off|on(默认值)}  决定sqlplus在终端输出中如何格式化空白空间。为off时,在输出中使用空格格式化空白空间;为on时,用tab字符。tab的缺省值依赖于系统,用show tab命令可查看该缺省值。
   
   termout {off|on(默认值)}  控制由文件执行命令所产生的输出的显示。off禁止显示,以致从一个命令文件假脱机输出,在屏幕上看不到输出;on时显示输出。termout off 不影响交互地进行命令的输出。
   
   time {off(默认值)|on}  控制当前日期的显示。on时,在每条命令提示前显示当前时间;off时禁止时间的显示。
   
   timing {off(默认值)|on}  控制时间统计的显示。on时,显示每一个运行的sql命令或pl/sql块的时间统计;off时,禁止每一个命令的时间统计。
   
   trimout {off|on(默认值)}  决定sqlplus在每一显示行的末端是否允许带空格。on时将每行尾部的空格去了,特别当从慢速的通信设备存取sqlplus时可改进性能;off时允许sqlplus显示尾部的空格。trimout on不影响假脱机输出。设置tab on时,sqlplus忽略trimout on。
   
   underline {-(默认值)|c|off|on(默认值)}  设置用在sqlplus报表中下划线列标题的字符。on或off将下划线置成开或关。
   
   verify {off|on(默认值)}  控制sqlplus用值替换前、后是否列出命令的文本。on时显示文本;off时禁止列清单。

   wrap {off|on(默认值)}  控制sqlplus是否截断数据项的显示。off时截断数据项;on时允许数据项缠绕到下一行。在column命令中使用wrapped和truncated子句可控制对指定列的wrap的设置。

阅读(1562) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~