請移步https://higoge.github.io/,全部下載資料在那個博客都能找到。謝謝。 mysql
--------------------------------------------------------------------linux
最近使用Shell編程編輯文件的時候,學習到了Here Document。感受不錯,分享給你們。git
Here Document是已「<<空格變量」爲標識的一段Shell程序,不知道這麼理解是否準確。github
咱們知道日常在linux命令行的操做均可以放到文件裏面,賦予可執行權限後,就能夠將這文件變成一個shell腳本。可是若是咱們跟有些程序交互時,shell腳本卻幫不了咱們太多。好比編輯一個文件和操做數據庫。編輯一個文件通常用vi,進去後hjkl的aio的操做什麼的,腳本怎麼執行?mysql登錄輸入mysql -u 用戶 -p 密碼後,就跟mysql進行一串交互,shell怎麼執行?Here Document就能夠派上用場了。sql
這裏就寫Here Document的兩個應用。shell
1. shell編輯文件。數據庫
shell編輯文件最經常使用的方法就是echo 字符串 >> 文件。可是要刪除一行怎麼辦?Here Document就搞定了。編程
經Jeremiah測試,在Here Document中使用vi是不行的。替代方法是使用ed命令。在命令行執行如下:ide
$ touch base.txt
$ ed base.txt
a
this is line1.
this is line2.
this is line3.
this is line4.
.
wq學習
先新建一個文件base.txt,而後ed這個文件,輸入a表示最後追加,輸入了四行文字。.表示結束輸入。wq表示保存退出。
那咱們再用ed命令,在shell腳本里面對這個文件再次進行操做。以下。
#!/bin/sh
ed base.txt << !ED1_JEREMIAH!
3
d
i
this is line 3 new.
.
w
q
!ED1_JEREMIAH!
解釋下:ed base.txt << !ED1_JEREMIAH! 表示編輯base.txt,用變量!ED1_JEREMIAH!標記,這裏搞的變量複雜爲了和shell中的其餘變量進行區分。3表示到第3行,d表示刪除,而後i表示本行增長,輸入this is line 3 new。其餘的同上述。最後用!ED1_JEREMIAH!結束。也就是說兩個!ED1_JEREMIAH!之間的每一行都是相似與命令行輸入到ed名中,進行交互。
執行的結果以下所示。
$ sh ed_file.sh && cat base.txt
60
this is line3.
65
this is line1.
this is line2.
this is line 3 new.
this is line4.
關於ed的操做和參數,能夠查看linux幫助或去搜索相關的資料。
2. shell控制數據庫
假設執行下面的操做訪問數據庫。
$ mysql -u root
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1257
Server version: 5.1.35-community MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
mysql> select * from user;
mysql> exit
Bye
若是咱們要用shell腳本訪問,則能夠編寫以下的腳本。
#!/bin/sh
mysql -u root << !ED2_JEREMIAH!
use mysql
select * from user;
exit
!ED2_JEREMIAH!
執行以下。
sh mysql_access.sh
能夠看到結果相同。
在網上還看到過能夠將查詢的結果放置到Shell的變量中,這種高級操做你們有興趣的本身去Google吧。
寫在最後:只要是命令行與程序進行交互,用shell腳本的Here Document均可以實現。體會上面兩處的用法,Jeremiah估計任何交互都能搞定。上面寫的都是Jeremiah本身的理解,不必定很到位,歡迎批評指正。