shell here document 应用实例--shell控制数据库



 

 

    最近使用Shell编程编辑文件的时候,学习到了Here Document。感觉不错,分享给大家。

 

 

 

    Here Document是已“<<空格变量”为标识的一段Shell程序,不知道这么理解是否准确。

 

 

 

    我们知道平常在linux命令行的操作都可以放到文件里面,赋予可执行权限后,就可以将这文件变成一个shell脚本。但是如果我们跟有些程序交互时,shell脚本却帮不了我们太多。比如编辑一个文件和操作数据库。编辑一个文件一般用vi,进去后hjklaio的操作什么的,脚本怎么执行?mysql登陆输入mysql -u 用户 -p 密码后,就跟mysql进行一串交互,shell怎么执行?Here Document就可以派上用场了。

 

 

 

    这里就写Here Document的两个应用。

 

 

 

    1. shell编辑文件。

 

     shell编辑文件最常用的方法就是echo 字符串 >> 文件。但是要删除一行怎么办?Here Document就搞定了。

 

    经Jeremiah测试,在Here Document中使用vi是不行的。替代方法是使用ed命令。在命令行执行以下:

 

$ touch base.txt 

$ ed base.txt 

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! 

this is line 3 new. 

!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自己的理解,不一定很到位,欢迎批评指正。

 

本文出自 “海狗哥的流媒体空间” 博客,请务必保留此出处http://jeremiah.blog.51cto.com/539865/339211

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值