如何格式化我的oracle查询以使列不包装?

som*_*guy 28 oracle sqlplus

我试过这个,但它不起作用:

col * format a20000
Run Code Online (Sandbox Code Playgroud)

我真的必须专门列出每一栏吗?这对屁股来说是一个巨大的痛苦.

som*_*guy 39

没关系,想通了:

set wrap off
set linesize 3000 -- (or to a sufficiently large value to hold your results page)
Run Code Online (Sandbox Code Playgroud)

我发现的是:

show all
Run Code Online (Sandbox Code Playgroud)

并寻找一些似乎相关的选项.

  • 好吧,想出来(再次):set wrap off set linesize 3000 //或者非常大的东西呃. (3认同)
  • 从头开始,将换行设置为关闭确实会禁用换行。但现在这条线被截断了。$%*! (2认同)

Pat*_*uff 25

我使用一个通用查询,我称之为"转储"(为什么?我不知道),看起来像这样:

SET NEWPAGE NONE
SET PAGESIZE 0
SET SPACE 0
SET LINESIZE 16000
SET ECHO OFF
SET FEEDBACK OFF
SET VERIFY OFF
SET HEADING OFF
SET TERMOUT OFF
SET TRIMOUT ON
SET TRIMSPOOL ON
SET COLSEP |

spool &1..txt

@@&1

spool off
exit
Run Code Online (Sandbox Code Playgroud)

然后我调用SQL*Plus传递我想要作为参数运行的实际SQL脚本:

sqlplus -S user/password@database @dump.sql my_real_query.sql
Run Code Online (Sandbox Code Playgroud)

结果写入文件

my_real_query.sql.txt

.