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

上次我们介绍了: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在存储过程中编写事务处理代码的三种方法

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/264251.html<

(0)
运维的头像运维
上一篇2025-05-04 22:53
下一篇 2025-05-04 22:55

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注