文章目录
- 一. EOF简介
- 二. 语法
- 三. cat <<EOF 与 cat <<-EOF
- 四. shell执行多条sql
一. 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} <<-EOFuse 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
说明:
2>/dev/null:代表屏蔽所有错误
两个例子的作用都是将cat命令输出的追加到 test.sh
cat << EOF >> test.sh
cat > test.sh << EOF