请移步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本身的理解,不必定很到位,欢迎批评指正。