SQL/PLUS学习笔记之ECHO和SPOOL的使用_Oracle_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Oracle > SQL/PLUS学习笔记之ECHO和SPOOL的使用

SQL/PLUS学习笔记之ECHO和SPOOL的使用

 2013/8/10 1:23:00    程序员俱乐部  我要评论(0)
  • 摘要:上次我们介绍了:SQL/PLUS学习笔记之编辑缓冲区中的当前行命令,本文我们介绍一下SQL/PLUS学习笔记之ECHO和SPOOL的使用,接下来就让我们一起来了解一下这部分内容。ECHO参数的设置:SQL>showecho--显示echo的状态echoOFF--此时echo是OFF状态SQL>setechoon--设置其为开状态SQL>showechoechoON--已经打开此时运行脚本的话,脚本中的每条SQL语句或PL/SQL块将会显示在终端,如下运行test脚本
  • 标签:笔记 学习 使用 SQL 学习笔记

上次我们介绍了:SQL/PLUS学习笔记之编辑缓冲区中的当前行命令,本文我们介绍一下SQL/PLUS学习笔记之ECHOSPOOL的使用,接下来就让我们一起来了解一下这部分内容。

ECHO参数的设置:

SQL> show echo --显示echo的状态

echo OFF --此时echo是OFF状态

SQL> set echo on --设置其为开状态

SQL> show echo

echo ON --已经打开

此时运行脚本的话,脚本中的每条SQL语句或PL/SQL块将会显示在终端,如下运行test脚本:

    class="dp-xml">
  1. SQL> @test --其下面均为终端显示的内容  
  2. SQL> select *from t1 where rownum<2;  
  3.  
  4. ID NAME  
  5. ---------- --------------------  
  6. 1 Testing  
  7.  
  8. SQL>   
  9. SQL> truncate table t1;  
  10.  
  11. Table truncated.  
  12.  
  13. SQL>   
  14. SQL> begin  
  15. 2   
  16. 3 for i in 1 .. 1000 loop  
  17. 4   
  18. 5 insert into t1 values(i,'Testing');  
  19. 6 end loop;  
  20. 7 commit;  
  21. 8   
  22. 9 end;  
  23. 10 /  
  24.  
  25. PL/SQL procedure successfully completed.  
  26.  
  27. SQL>   
  28. SQL> select count(*)from t1;  
  29.  
  30. COUNT(*)  
  31. ----------  
  32. 1000 

使用SPOOL保存查询的结果集

  1. SQL> spool outputfile --默认在当前路径下生成outputfile.lst文件  
  2. SQL> select * from t1 where rownum<3;  
  3.  
  4. ID NAME  
  5. ---------- --------------------  
  6. 1 Testing  
  7. 2 Testing  
  8.  
  9. SQL> spool off --终止,此时这些内容全部被写入文件outputfile中  
  10.  
  11. [oracle@localhost ~]$ cat outputfile.lst --查看文件内容如下:  
  12. SQL> select * from t1 where rownum<3;  
  13.  
  14. ID NAME   
  15. ---------- --------------------   
  16. 1 Testing   
  17. 2 Testing   
  18.  
  19. SQL> spool off 

这个功能可以帮助生成一些动态的批量处理的脚本,比方说删除用户emcd下的满足某些条件的表:

  1. SQL> show user  
  2. USER is "EMCD"  
  3. SQL> spool droptable.sql  
  4. SQL> select 'drop table'||objec_name from user_objects where object_type='TABLE';  
  5. select 'drop table'||objec_name from user_objects where object_type='TABLE' 
  6. *  
  7. ERROR at line 1:  
  8. ORA-00904: "OBJEC_NAME": invalid identifier  
  9.  
  10. SQL> l  
  11. 1* select 'drop table'||objec_name from user_objects where object_type='TABLE' 
  12. SQL> c/objec_/object_  
  13. 1* select 'drop table'||object_name from user_objects where object_type='TABLE' 
  14. SQL> /  
  15.  
  16. 'DROPTABLE'||OBJECT_NAME  
  17. --------------------------------------------------------------------------------  
  18. drop tableT1  
  19. drop tableBIN$qokoVJ6g4HHgQAB/AQAzMg==$0  
  20. drop tableTOAD_PLAN_TABLE  
  21.  
  22. SQL> l  
  23. 1* select 'drop table'||object_name from user_objects where object_type='TABLE' 
  24. SQL> c/'drop table'/'drop table '  
  25. 1* select 'drop table '||object_name from user_objects where object_type='TABLE' 
  26. SQL> /  
  27.  
  28. 'DROPTABLE'||OBJECT_NAME  
  29. --------------------------------------------------------------------------------  
  30. drop table T1  
  31. drop table BIN$qokoVJ6g4HHgQAB/AQAzMg==$0  
  32. drop table TOAD_PLAN_TABLE  
  33.  
  34. SQL> spool off --结束输入  
  35. SQL> !  
  36.  
  37. [oracle@localhost ~]$ cat droptable.sql --查看输出内容,如下所示:  
  38.  
  39. SQL> select 'drop table'||objec_name from user_objects where object_type='TABLE';  
  40. select 'drop table'||objec_name from user_objects where object_type='TABLE' 
  41. *  
  42. ERROR at line 1:  
  43. ORA-00904: "OBJEC_NAME": invalid identifier   
  44.  
  45.  
  46. SQL> l  
  47. 1* select 'drop table'||objec_name from user_objects where object_type='TABLE' 
  48. SQL> c/objec_/object_  
  49. 1* select 'drop table'||object_name from user_objects where object_type='TABLE' 
  50. SQL> /  
  51.  
  52. 'DROPTABLE'||OBJECT_NAME   
  53. --------------------------------------------------------------------------------  
  54. drop tableT1   
  55. drop tableBIN$qokoVJ6g4HHgQAB/AQAzMg==$0   
  56. drop tableTOAD_PLAN_TABLE   
  57.  
  58. SQL> l  
  59. 1* select 'drop table'||object_name from user_objects where object_type='TABLE' 
  60. SQL> c/'drop table'/'drop table '  
  61. 1* select 'drop table '||object_name from user_objects where object_type='TABLE' 
  62. SQL> /  
  63.  
  64. 'DROPTABLE'||OBJECT_NAME   
  65. --------------------------------------------------------------------------------  
  66. drop table T1   
  67. drop table BIN$qokoVJ6g4HHgQAB/AQAzMg==$0   
  68. drop table TOAD_PLAN_TABLE   
  69.  
  70. SQL> spool off 

这样动态删除某些表的SQL语句就生成了。

关于SQL/PLUS学习笔记之ECHO和SPOOL的使用的知识就介绍到这里了,希望本次的介绍能够对您有所收获!

发表评论
用户名: 匿名