成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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命令

2011-08-19 15:48:13

SQL Server 結果集Sets使用技巧

2010-09-02 15:45:18

PHP函數echo

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查詢

2011-08-16 16:10:12

MySQLORDER BY子句GROUP BY子句

2011-08-16 15:35:50

MySQLSELECT語句FROM子句

2009-08-26 10:48:44

C# SQL命令

2009-09-17 16:20:43

Linq to sql

2021-12-20 20:30:48

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩在线精品 | 福利视频二区 | 日韩免费高清视频 | 国产乱码精品一区二区三区五月婷 | 亚洲久在线| 四虎成人av| 亚洲欧美国产精品久久 | 日韩国产在线观看 | 色爱综合网 | 亚洲va中文字幕 | 国产精品日产欧美久久久久 | 国产精品成人免费 | 一区二区三区四区视频 | 亚洲第一黄色网 | 日韩中文字幕一区二区 | 欧美一区二区三区久久精品 | 成人精品鲁一区一区二区 | 欧美黑人国产人伦爽爽爽 | 欧美中文字幕在线 | 国产欧美一区二区三区久久手机版 | 久在线| 亚洲国产精品一区二区三区 | 人人干免费 | 国产欧美精品在线 | 国产一区二区三区在线看 | 在线成人www免费观看视频 | www.日本在线观看 | 久久丝袜| 欧美视频精品 | 久久精品国产久精国产 | 色又黄又爽网站www久久 | 99久久精品免费看国产四区 | 久久久久亚洲 | 久久精品国产亚洲 | 久久久激情视频 | 亚洲最大的成人网 | 国产一区二区三区在线免费观看 | 欧美成人猛片aaaaaaa | 日日干干 | 国产日韩精品一区二区 | av一区二区三区四区 |