您的位置:首页 > 运维架构 > Shell

linux shell脚本 mysql多行命令执行

2015-07-20 11:48 573 查看
在linux终端执行mysql命令时,首先需要从终端进入到mysql命令行状态,在脚本编写时,要用到EOF(end of file)。

shell脚本中,通常将EOF与 << 结合使用,表示后续的输入作为子命令或子Shell的输入,直到遇到EOF为止,再返回到主Shell。

因此数据库连接和sql语句执行的脚本如下:

#!/bin/sh
mysql -u root -pcloud <<EOF 2>/dev/null
use nova;
alter table instance_types add column t_price double UNSIGNED ZEROFILL NULL DEFAULT NULL;
exit;
EOF


做特别解释:

1、在脚本中,第一行“#!/bin/sh“。”#!/bin/sh”是对shell的声明。#!后面要注明解释器,行中的解释器的路径必须是全路径。

2、在类Unix系统中,/dev/null,或称空设备,是一个特殊的设备文件,它丢弃一切写入其中的数据(但报告写入操作成功),读取它则会立即得到一个EOF。

在程序员行话,尤其是Unix行话中,/dev/null 被称为位桶(bit bucket)或者黑洞(black hole)。空设备通常被用于丢弃不需要的输出流,或作为用于输入流的空文件。这些操作通常由重定向完成。

3、“2>/dev/null”,2>是管道重新定向符号。 1 表示标准输出(一般就是终端屏幕),2是标准错误输出(一般也是屏幕)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: