linux shell脚本 mysql多行命令执行
2015-07-20 11:48
573 查看
在linux终端执行mysql命令时,首先需要从终端进入到mysql命令行状态,在脚本编写时,要用到EOF(end of file)。
shell脚本中,通常将EOF与 << 结合使用,表示后续的输入作为子命令或子Shell的输入,直到遇到EOF为止,再返回到主Shell。
因此数据库连接和sql语句执行的脚本如下:
做特别解释:
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是标准错误输出(一般也是屏幕)。
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是标准错误输出(一般也是屏幕)。
相关文章推荐
- hbase shell无法使用退格键的解决方案
- 希尔排序(shellsort)
- 常用的Bash快捷键
- BASH中用到的通配符和特殊符号
- BASH操作环境的一些笔记
- shell脚本-批量添加或删除用户
- 本地搭建Hadoop伪分布式环境之二:XShell连接Ubuntu
- Linux之认识和学习bash
- shell 中 seq的用法总结
- Linux shell 编程简单使用
- window7运行powershell
- 每日回顾Shell —cat,tail,head
- Shell编程中括号判断中赋值语句和判断语句
- Linux与Unix shell编程指南(完整高清版).pdf
- Linux与Unix shell编程指南(完整高清版).pdf
- shell 日期操作
- Shell脚本中实现字符串变量的去重功能
- shell脚本-添加用户(非交互式)
- Shell中while循环的done 后接一个重定向<
- shell中$0,$?,$!等的特殊用法