Shell腳本傳遞帶有空格的參數

  在另外一博文《Shell腳本實現DB2數據庫表導出到文件》中實現了經過腳本實現將DB2數據庫導出到文件,須要傳入七個參數,最後一個是一個帶有空格字符串,因此傳入的時候有點問題,會自動識別空格,默認會將空格前的看成第7個參數,如下是傳入的參數:html

MD duanwf 23742 CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first 100000 rows only

  最後的「fetch first 100000 rows only」爲第七個參數,可是識別的時候只獲取到fetch,日誌以下:linux

2014-10-15 17:51:59 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:70 - Run Command:   /home/duanwf/workspace/shell2.sh MD duanwf 23742 CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first 100000 rows only
2014-10-15 17:51:59 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - execute sql .................
2014-10-15 17:51:59 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - Begin to export the data: 
2014-10-15 17:51:59 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:51:59 ====================connect to MD=======================
2014-10-15 17:51:59 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:51:59 db2 connect to MD user duanwf 
2014-10-15 17:52:01 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:52:01 Succeed connect to MD 
2014-10-15 17:52:01 [Thread-9] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:52:01 export to /home/duanwf/asiainfo/export/T141015001_20141014.avl of del modified by nochardel codepage=1208 COLDEL&  select * from CDR_CALL_YYYYMMDD fetch:

  

  那要怎麼處理呢?sql

    以前問了有人說能夠用雙引號把他引發來,最後結果仍是同樣,沒法拿到,只能獲取到shell

"fetch

  仍是會自動在空格前自動斷開。數據庫

 

  能夠經過$@命令來處理,即將$7換成echo ${@:7},這樣將自動識別到的第7個開始,所有獲取到做爲最後第7個參數,參數獲取改成:bash

#!/bin/bash
 
DBSCHEMA=$1
DBUSER=$2
DBPASSWORD=$3
TABLENAME=$4
FILEPATH=$5
DELIMITER=$6
EXPORTLIMIT=`echo ${@:7}`

  再次運行結果:函數

2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:57 - Export Parameters: MD duanwf 23742 ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first 100000 rows only
2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:70 - Run Command:   /home/duanwf/workspace/shell/db2.sh MD duanwf 23742 ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first 100000 rows only
2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - execute sql .................
2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - Begin to export the data: 
2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:05 ====================connect to MD=======================
2014-10-15 23:36:05 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:05 db2 connect to MD user duanwf 
2014-10-15 23:36:08 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:08 Succeed connect to MD 
2014-10-15 23:36:08 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:08 export to /home/duanwf/asiainfo/export/M141015003_201409.avl of del modified by nochardel codepage=1208 COLDEL&  select * from ST_ZGD_SCOPE_RSFR_GR_DM_201409 fetch first 100000 rows only: 
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - SQL3104N  EXPORT 實用程序 正在開始將數據導出至文件
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - "/home/duanwf/asiainfo/export/M141015003_201409.avl"2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - SQL3105N  Export 實用程序已經完成導出 "12742" 行。
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 
2014-10-15 23:36:09 [Thread-2] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 導出的行數:12742

問題解決!!fetch

 

<--------------------------------- 我是華麗的分割線 --------------------------------->spa

 

補充對Shell函數參數的說明:日誌

來源:http://www.w3cschool.cc/linux/linux-shell-func.html

 

在Shell中,調用函數時能夠向其傳遞參數。在函數體內部,經過 $n 的形式來獲取參數的值,例如,$1表示第一個參數,$2表示第二個參數...

帶參數的函數示例:

#!/bin/bash
funWithParam(){
    echo "The value of the first parameter is $1 !"
    echo "The value of the second parameter is $2 !"
    echo "The value of the tenth parameter is $10 !"
    echo "The value of the tenth parameter is ${10} !"
    echo "The value of the eleventh parameter is ${11} !"
    echo "The amount of the parameters is $# !"
    echo "The string of the parameters is $* !"
}
funWithParam 1 2 3 4 5 6 7 8 9 34 73

輸出結果:

The value of the first parameter is 1 !
The value of the second parameter is 2 !
The value of the tenth parameter is 10 !
The value of the tenth parameter is 34 !
The value of the eleventh parameter is 73 !
The amount of the parameters is 12 !
The string of the parameters is 1 2 3 4 5 6 7 8 9 34 73 !"

注意,$10 不能獲取第十個參數,獲取第十個參數須要${10}。當n>=10時,須要使用${n}來獲取參數。

另外,還有幾個特殊字符用來處理參數:

參數處理 說明
$# 傳遞到腳本的參數個數
$* 以一個單字符串顯示全部向腳本傳遞的參數
$$ 腳本運行的當前進程ID號
$! 後臺運行的最後一個進程的ID號
$@ 與$#相同,可是使用時加引號,並在引號中返回每一個參數。
$- 顯示Shell使用的當前選項,與set命令功能相同。
$? 顯示最後命令的退出狀態。0表示沒有錯誤,其餘任何值代表有錯誤。
相關文章
相關標籤/搜索