[20210510]變態的windows批處理7.txt
[20210510]變態的windows批處理7.txt
--//想寫一個批處理在windows下,遇到一個奇怪的問題,記錄自己的分析過程.
d:\>seq 3 | xargs -iQ echo "alter session set optimizer_index_cost_adj = Q;\nselect count(name) from from t where id=1;"
;lter session set optimizer_index_cost_adj = 1
select count(name) from from t where id=1;
;lter session set optimizer_index_cost_adj = 2
select count(name) from from t where id=1;
;lter session set optimizer_index_cost_adj = 3
select count(name) from from t where id=1;
--//很奇怪,分號跑到最前面,什麼回事,加入多個空格,繼續測試:
d:\>seq 3 | xargs -iQ echo "alter session set optimizer_index_cost_adj = Q ;\nselect count(name) from from t where id=1;"
;ter session set optimizer_index_cost_adj = 1
select count(name) from from t where id=1;
;ter session set optimizer_index_cost_adj = 2
select count(name) from from t where id=1;
;ter session set optimizer_index_cost_adj = 3
select count(name) from from t where id=1;
--//視乎Q後面的字元都會到前面.
d:\>seq 3 | xargs -iQ echo "alter session set optimizer_index_cost_adj = Q ;\nselect count(name) from from t where id=1;" > aa.txt
--//使用vim下開啟發現問題所在:
alter session set optimizer_index_cost_adj = 1
;
select count(name) from from t where id=1;
alter session set optimizer_index_cost_adj = 2
;
select count(name) from from t where id=1;
alter session set optimizer_index_cost_adj = 3
;
select count(name) from from t where id=1;
--//可以發現後面多了一個^M,實際上就是回車字元\r.導致顯示輸出感覺分號跑到前面.
--//實際上問題出在seq的輸出以及windows對於文字格式的處理,windows文字預設是回車換行.
--//對於windows下的seq的輸出也包含回車換行與linux的seq輸出有一點點不通.知道問題所在解決就很簡單.加入一個tr處理就ok了.
d:\>seq 3 | tr -d '\r' |xargs -iQ echo "alter session set optimizer_index_cost_adj = Q;\nselect count(name) from from t where id=1;"
alter session set optimizer_index_cost_adj = 1;
select count(name) from from t where id=1;
alter session set optimizer_index_cost_adj = 2;
select count(name) from from t where id=1;
alter session set optimizer_index_cost_adj = 3;
select count(name) from from t where id=1;
--//另外一個細節要注意xargs後面呼叫的命令echo是外部命令,windows下的內部命令echo也很變態.看下面的例子:
d:\>echo '123' "456"
'123' "456"
d:\>D:\tools\linux\usr\local\wbin\echo '123' "456"
'123' 456
--//注意看兩者的區別,windows下命令列僅僅將雙引號的作為字串,而單引號不是.導致awk命令在windows寫的很難看或者難寫.
--//我個人建議widnows下還是在Cygwin64 Terminal下使用來寫shell指令碼.看下面的輸出:
$ echo '123' "456"
123 456
--//總之,windows下會變得非常麻煩.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2771852/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20190219]變態的windows批處理6.txtWindows
- [20211207]變態的windows批處理10.txtWindows
- [20211011]變態的windows批處理9.txtWindows
- Windows批處理中的變數和值Windows變數
- 開啟windows批處理大門Windows
- 07 Windows批處理之檔案操作Windows
- Windows 批處理之DATE命令的使用方法Windows
- 04 Windows批處理中的條件執行Windows
- 批處理-刪除環境變數變數
- windows 批處理備份目錄指令碼Windows指令碼
- Windows10系統優化(批處理)Windows優化
- 08 Windows批處理之執行編譯後的程式Windows編譯
- [20180319]windows批處理檔案大小比較.txtWindows
- 修改windows遠端桌面連線埠-批處理Windows
- [20230208]windows批處理檢測隨身碟.txtWindows
- 批處理概述
- Apache Beam,批處理和流式處理的融合!Apache
- 03 Windows批處理的作用域和延遲擴充套件Windows套件
- 10 Windows批處理之呼叫例程和bat檔案WindowsBAT
- java當中的批處理Java
- JDBC當中的批處理JDBC
- Jenkins執行遠端Windows批處理的許可權問題JenkinsWindows
- 05 Windows批處理中的字串和布林資料型別Windows字串資料型別
- 09 Windows批處理之標籤和無序執行Windows
- cmd批處理無法使用 提示windows找不到檔案Windows
- 批處理指令碼來修復並開啟Windows 7中的Windows Defender防火牆指令碼Windows防火牆
- Windows使用批處理給手機批量安裝apk檔案WindowsAPK
- 什麼是批處理
- Dynamics CRM 2013 批處理
- bat 批處理字串操作BAT字串
- window 批處理檔案
- MongoDB for Windows使用批處理檔案啟動閃退之空格惹的禍MongoDBWindows
- 06 Windows批處理之整數和浮點資料型別Windows資料型別
- Windows Ping的結果顯示每次ping的時間的bat批處理指令碼WindowsBAT指令碼
- 簡單實現批處理
- Python批處理:檔案操作Python
- MPP架構和批處理架構
- bat批處理常用指令碼BAT指令碼