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

数据库 Oracle
如果想在终端将每执行的一条SQL语句都打印出来需要设置SQL/PLUS的ECHO参数,那么ECHO参数该如何设置呢?本文我们就介绍这部分内容,希望能够对您有所帮助。

上次我们介绍了: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脚本:

  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的使用的知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. SQL Server数据库远程查询并批量导入数据
  2. 存储过程:sp_MSforeachtable/sp_MSforeachdb
  3. SQL Server数据库获取所有表和数据的批量操作
  4. 关于使用数据库登录名和数据库用户名的一些心得
  5. SQL Server在存储过程中编写事务处理代码的三种方法

 

责任编辑:赵鹏 来源: CSDN博客
相关推荐

2011-08-16 09:48:27

SQLPLUS学习笔记SQL Buffer

2011-08-16 10:09:30

SQLPLUS学习笔记SQL的自动提交功能

2011-08-16 10:29:10

SQLPLUS学习笔记编辑缓冲区中的当前行命

2011-08-29 11:38:18

SQL Server 联合结果集union

2009-11-05 17:53:59

Oracle导出SQL

2010-09-02 15:42:37

echo命令

2010-09-02 15:45:18

PHP函数echo

2011-08-19 15:48:13

SQL Server 结果集Sets使用技巧

2011-08-22 11:23:41

SQL Server 数据修改

2010-05-21 11:07:36

2011-08-29 13:10:59

SQL Server 给新加字段赋值

2011-08-30 16:26:34

Hadoop

2011-03-08 16:30:24

Proftpd

2011-03-08 16:30:40

Proftpd

2011-08-19 15:13:36

SQL Server MDX查询

2009-09-17 16:20:43

Linq to sql

2011-08-16 16:10:12

MySQLORDER BY子句GROUP BY子句

2009-08-26 10:48:44

C# SQL命令

2021-12-20 20:30:48

鸿蒙HarmonyOS应用

2011-08-16 15:35:50

MySQLSELECT语句FROM子句
点赞
收藏

51CTO技术栈公众号