在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是标准错误输出(一般也是屏幕)。