请问如何在sqlplus命令行下导出向pl/sql导出用户对象的那种内容?

请问如何在sqlplus命令行下导出向pl/sql导出用户对象的那种内容?例如导出建表语句,存储过程等等。非常感谢~~

阅读 4.8k
1 个回答

把下面的内容存到一个文件中,在sqlplus中直接运行,可以把当前用户下的表定义导出来。
为测试限制只输出前10个表,真正用的时候根据需求进行调整。

set echo off
set feedback off
set heading off
set termout off
set trimspool on
set pagesize 0
set linesize 10000
set long 20000
set longchunksize 20000
set colsep '    '

spool /home/oracle/table_ddl.txt
SELECT DBMS_METADATA.GET_DDL('TABLE', table_name) FROM user_tables
WHERE ROWNUM <= 10;
spool off

如果需要可查询表、索引、授权等比较完整的信息,建议写个存储过程,DBMS_METADATA.GET_DDL可以获取表、索引、存储过程的定义,USER_INDEXES中可以查出表和索引的对应关系,用户授权也有对应的表可以查询到,主要是USER_SYS_PRIVS、 USER_TAB_PRIVS、USER_ROLE_PRIVS这几张表。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏