一. EOF简介
在shell脚本中,通常将EOF与 << 结合使用,表示后续的输入作为子命令或子Shell的输入,直到再遇到EOF为止,再返回到主Shell。EOF( 即 end of file )只是一个分界符。
EOF一般会配合cat能够多行文本输出,本文最后实现通过EOF执行多条sql。
二. 语法
command<<EOF
(内容)
EOF
# <<是输入重定向,将EOF中间的内容让command命令读取
还可以自定义,比如自定义:
command<<ABC #开始
....
ABC #结束
三. cat <<EOF 与 cat <<-EOF
两个都是获取stdin,并在EOF处结束stdin,输出stdout。
在我们使用cat <<EOF时,我们输入完成后,需要在一个新的一行输入EOF结束stdin的输入。
EOF必须顶行写,前面不能用制表符或者空格。
比如,下面的语句就不会出错:
cat <<EOF
Hello,world!
EOF
如果结束分界符EOF前有制表符(只是tab键),则EOF不会被当做结束分界符,只会继续被当做stdin来输入。
cat <<-EOF
Hello,world!
EOF
注意结尾的EOF前面必须是tab键,如果存在空格还是不会结束。
四. shell执行多条sql
#!/bin/sh
mysql_command="mysql -h ${hostname} -u${username} -p${password}" 2>/dev/null
${mysql_command} <<-EOF
use hivedb;
alter table TBLS modify column TBL_NAME varchar(1000) character set utf8;
alter table COLUMNS_V2 modify column COMMENT varchar(256) character set utf8;
alter table TABLE_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;
alter table PARTITION_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;
alter table PARTITION_KEYS modify column PKEY_COMMENT varchar(4000) character set utf8;
alter table INDEX_PARAMS modify column PARAM_VALUE varchar(4000) character set utf8;
EOF
说明:文章来源:https://www.toymoban.com/news/detail-528478.html
2>/dev/null:代表屏蔽所有错误
两个例子的作用都是将cat命令输出的追加到 test.sh
cat << EOF >> test.sh
cat > test.sh << EOF文章来源地址https://www.toymoban.com/news/detail-528478.html
到了这里,关于【shell】通过EOF实现一个链接执行多条sql的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!