I'm trying to generate all DDLs for objects in a Database using the SPOOL command in SQLPLUS:
SET trimspool ON
SET wrap off
SET heading off
SET linesize 300
SET echo off
SET pages 999
SET long 90000
Col object_type format a10000
Col object_name format a10000
Col owner format a10000
spool export.out
SELECT DBMS_METADATA.GET_DDL(object_type, object_name, owner)
FROM all_OBJECTS
WHERE OWNER = 'DMALM'
and object_type not like '%PARTITION'
and object_type not like '%BODY'
and object_type not like '%LOB';
spool off
quit
But the output file I get is cut at col #80. How can I prevent the output file from being wrapped?
You need to also do:
SET longchunksize 90000
The default width of datatype columns is the width of the column in the database. The column width of a
LONG
,BLOB
,BFILE
,CLOB
,NCLOB
orXMLType
defaults to the value ofSET LONGCHUNKSIZE
orSET LONG
, whichever is the smaller.
You're setting LONG
already, but LONGCHUNKSIZE
is still at its default value of 80, so you need to increase that to match. You can see all your current settings with show all
.
This preserves the line breaks and indentation applied by default.