Oracle通過Sqlplus結合Shell指令碼方式生成Excel檔案
一、問題描述
今天接到一個任務,是要求每天通過SQL指令碼生成excel檔案,並且自動傳送到相關人員郵箱。這個需求我還真是沒有做過,之前只做過通過SQL指令碼生成為HTML網頁檔案。於是乎,我又開始的學習過程,如今的Internet時代,解決問題就是easy,很快就找到了eygle的部落格(使用SQL*PLUS,構建完美excel或html輸出http://www.eygle.com/archives/2005/04/eoasqlplusieaae.html)。下面是學習過程中的實驗部分。
二、實驗
1.建立測試表
2.編輯 main.sql
3.編輯 get_tables.sql
4.編輯執行檔案 collect.sh
5.給collect.sh 執行許可權
6.執行
-
SAM@dzwj > create table test1(id int,name varchar2(10),loc varchar2(30),hire_date date,email varchar2(20),department varchar2(20));
-
Table created.
-
-
SAM@dzwj > insert into test1 values (1,'sam1','beijing',sysdate,'sam1@oracle.com','it');
-
1 row created.
-
SAM@dzwj > insert into test1 values (2,'sam2','beijing',sysdate,'sam2@oracle.com','it');
-
1 row created.
-
SAM@dzwj > insert into test1 values (3,'sam3','beijing',sysdate,'sam3@oracle.com','it');
-
1 row created.
-
SAM@dzwj > insert into test1 values (4,'sam4','beijing',sysdate,'sam4@oracle.com','it');
-
1 row created.
-
SAM@dzwj > insert into test1 values (5,'sam5','beijing',sysdate,'sam5@oracle.com','it');
-
1 row created.
-
-
SAM@dzwj > SAM@dzwj > commit;
-
Commit complete.
-
-
SAM@dzwj > select * from test1;
-
-
ID NAME LOC HIRE_DATE EMAIL DEPARTMENT
-
---------- ---------- ------------------------------ ------------------ -------------------- --------------------
-
1 sam1 beijing 28-NOV-17 sam1@oracle.com it
-
2 sam2 beijing 28-NOV-17 sam2@oracle.com it
-
3 sam3 beijing 28-NOV-17 sam3@oracle.com it
-
4 sam4 beijing 28-NOV-17 sam4@oracle.com it
- 5 sam5 beijing 28-NOV-17 sam5@oracle.com it
2.編輯 main.sql
-
[oracle@testdb ~]$ cat main.sql
-
set linesize 200 pagesize 10000
-
set term off verify off feedback off
-
set markup html on entmap on spool on preformat off
-
alter session set NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
-
spool /home/oracle/test1.xls
-
@/home/oracle/get_tables.sql
-
spool off
- exit
3.編輯 get_tables.sql
-
[oracle@testdb ~]$ cat get_tables.sql
- select * from test1;
4.編輯執行檔案 collect.sh
-
[oracle@testdb ~]$ cat collect.sh
-
#!/bin/bash
-
. /home/oracle/.bash_profile
-
DATE=`date +%Y%m%d`
-
sqlplus sam/oracle@dzwj @/home/oracle/main
- mv /home/oracle/test1.xls /home/oracle/test1_${DATE}.xls
5.給collect.sh 執行許可權
- [oracle@testdb ~]$ chmod u+x collect.sh
6.執行
-
[oracle@testdb ~]$ ./collect.sh
-
-
SQL*Plus: Release 11.2.0.4.0 Production on Wed Nov 29 11:00:19 2017
-
-
Copyright (c) 1982, 2013, Oracle. All rights reserved.
-
-
-
Connected to:
-
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
-
With the Partitioning, OLAP, Data Mining and Real Application Testing options
-
-
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
- With the Partitioning, OLAP, Data Mining and Real Application Testing options
7.驗證
將檔案傳回到本地機器開啟,得到想要的excel檔案
三、總結
生活在Internet時代真是件幸福的事,此次任務算是告一段落,但是當中還是碰到一些小problems,比如一開始沒有加時間NLS_DATE_FORMAT變數的修改,匯出的時間型別資料時沒有時間,只有年月日。總而言之,多學習,多實踐,沒錯的。向eygle大神致謝。 Where there is a will, there is a way.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26148431/viewspace-2147929/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [ Shell ] 通過 Shell 指令碼匯出 GDSII/OASIS 檔案指令碼
- Shell指令碼 | 抓取log檔案指令碼
- [ Shell ] 通過 Shell 指令碼匯出 CDL 網表指令碼
- 通過shell指令碼防止埠掃描指令碼
- shell指令碼之批次清空檔案指令碼
- 通過shell指令碼 批量新增使用者指令碼
- shell指令碼技巧—建立和清空檔案指令碼
- 通過shell指令碼批量操作mysql資料庫指令碼MySql資料庫
- 共享一個iptables的shell指令碼檔案指令碼
- shell 備份檔案指令碼+自動清理指令碼
- Shell指令碼逐行處理文字檔案技巧指令碼
- 流式生成Excel檔案Excel
- POI生成EXCEL檔案Excel
- java 生成 excel檔案JavaExcel
- shell指令碼總結指令碼
- 通過shell指令碼檢測MySQL服務資訊指令碼MySql
- linux 查詢某個日期以後修改過哪些檔案 shell指令碼Linux指令碼
- oracle自帶指令碼說明(rdbms,ctx,sqlplus,javavm)Oracle指令碼SQLJava
- [20191104]sqlplus 管道檔案 過濾.txtSQL
- 如何在Shell指令碼中逐行讀取檔案指令碼
- Linux shell:執行shell指令碼的幾種方式Linux指令碼
- PowerDesigner: 利用sql指令碼檔案逆生成模型SQL指令碼模型
- 第22篇 生成proto檔案bat指令碼BAT指令碼
- 案例四:Shell指令碼生成隨機密碼指令碼隨機密碼
- Linux通過Shell指令碼命令修改密碼不需要互動Linux指令碼密碼
- 如何讓shell指令碼變成可執行檔案指令碼
- 通過 shell 指令碼完成 GitLab11.9.11 的一鍵安裝指令碼Gitlab
- 如何在shell指令碼里使用sftp批次傳送檔案指令碼FTP
- Linux系統配置檔案簡易shell備份指令碼Linux指令碼
- shell指令碼之刪除固定天數之前的檔案指令碼
- 使用shell指令碼替換csv檔案中的資料指令碼
- Class檔案結構&位元組碼指令
- Oracle批次生成Merge指令碼程式Oracle指令碼
- 案例:通過shell指令碼實現mysql資料備份與清理指令碼MySql
- mssql sqlserver 使用指令碼輸出excel檔案的方法分享SQLServer指令碼Excel
- 讀取本地Excel檔案生成echartsExcelEcharts
- Java 根據模板生成 PDF 檔案 以及 excel 檔案JavaExcel
- shell指令碼指令碼
- 多個excel檔案合併成一個excel表的方法 如何快速合併多個excel檔案Excel