1.在文件里面输入一系列命令,可以直接执行吗?
可以。作者认为,这时调用的是当前用户默认使用的shell。
如果其中一个命令有错,后面的命令还是会继续执行下去的
如果说使用了”&&” ,如果前面的命令执行错误,,后面的命令不执行。
2.加#/bin/bash目的是什么,既然不加也可以?
这些不是注释符,而是说明下面的脚本是在什么shell下面运行的,并且以该shell环境来执行脚本。Linux中的shell有多种类型,其中最常用的几种是Bourne shell(sh)、C shell(csh)和Korn shell(ksh)。三种shell各有优缺点。Bourne shell是UNIX最初使用的shell,并且在每种UNIX上都可以使用。Bourne shell在shell编程方面相当优秀,但在处理与用户的交互方面做得不如其他几种shell。Linux操作系统缺省的shell是Bourne Again shell,它是Bourne shell的扩展,简称Bash,与Bourne shell完全向后兼容,并且在Bourne shell的基础上增加、增强了很多特性。
一个简单的例子
#!/bin/ksh 一定放在第一行
export LOG=/tmp/test.log
exec >> $LOG 2>&1
echo "a test message!"
exit 0
在AIX下面编辑好该脚本后直接执行,运行成功在/tmp下面会有一个test.log文件生成,文件内容为"a test message!"
如果我们把上面的
#!/bin/ksh
换成
#!/bin/csh
执行脚本,则会有如下报错:
export不是shell命令
即,在csh里面没有export这个命令,所以会报错。
3.
关于#!/bin/bash和#!/bin/sh #!/bin/bash是指此脚本使用/bin/bash来解释执行。 其中,#!是一个特殊的表示符,其后,跟着解释此脚本的shell路径。 bash只是shell的一种,还有很多其它shell,如:sh,csh,ksh,tcsh,... 我们可以通过以下一个示例来进行实验,了解#!/bin/bash的使用。 除第一行外,脚本中所有以“#”开头的行都是注释。 1)#!/bin/bash只能放在第一行,如果后面还有#!,那么只能看成是注释。 这里有三个脚本(脚本都要使用”chmod +x scriptname“命令来获得可执行权限): tbash1.sh: #!/bin/sh source abc echo "hello abc" tbash2.sh: #!/bin/bash source abc echo "hello abc" tbash3.sh: source abc echo "hello abc" 三个脚本执行的结果: [ns ocalhost other]$ ./tbash1.sh ./tbash1.sh: line 2: abc: No such file or directory 注:当source命令执行有问题时,sh不再往下面执行。 [nsvc@localhost other]$ ./tbash2.sh ./tbash2.sh: line 2: abc: No such file or directory hello abc 注:当source命令执行有问题时,bash继续执行下面命令。 [nsvc@localhost other]$ ./tbash3.sh ./tbash3.sh: line 1: abc: No such file or directory hello abc 注:自身登录
在的shell是bash。所以,当source命令执行有问题时,bash继续执行下面命令。 如果将tbash1.sh改成: echo "abc" #!/bin/sh source abc echo "hello abc" 那么,执行结果是: [nsvc@localhost other]$ ./tbash1.sh abc ./tbash1.sh: line 3: abc: No such file or directory hello abc 也就是说,脚本忽略了第二行“#!/bin/sh",直接使用当前所在的shell(也就是bash)来解释脚本。 当把tbash1.sh改成: #!/bin/sh #!/bin/bash source abc echo "hello abc" 执行结果为: [nsvc@localhost other]$ ./tbash1.sh ./tbash1.sh: line 3: abc: No such file or directory 当执行完source命令时,并没有往下执行。说明,#!/bin/sh这一行起到作用了,但#!/bin/bash并没有起作用。在脚本中,除第一行外,脚本中所有以“#”开头的行都是注释。 2)#!后面的路径一定要正确,不正确会报错。 假如,我们把tbash1.sh中第一行的#!后面加了一个不存在的路径”/home/sh“: #!/home/sh source abc echo "hello abc" 执行结果为: [nsvc@localhost other]$ ./tbash1.sh -bash: ./tbash1.sh: /home/sh: bad interpreter: No such file ordirectory 系统会提示/home/sh的路径不存在。 3)如果一个脚本在第一行没有加上#!+shell路径这一行,那么,脚本会默认当前用户登录的shell,为脚本解释器。 在1)中,脚本tbash3.sh的执行结果,就是用当前自己登录的shell(bash)解释后的结果。我们通常所用的shell都是bash,如果哪天登录到sh,再使用以上类型的脚本,就会有问题。以下是自己登录到sh下,执行tbash3.sh的结果: -sh-3.2$ ./tbash3.sh ./tbash3.sh: line 1: abc: 没有那个文件或目录 与1)中的执行结果是不一样的。 因此,大家应该养成脚本首行加上#!+shell路径的习惯。 4)/bin/sh相当于/bin/bash --posix 我们将脚本tbash1.sh改为: #!/bin/bash --posix source abc echo "hello abc" 执行结果: [nsvc@localhost other]$ ./tbash1.sh ./tbash1.sh: line 2: abc: No such file or directory 与tbash1.sh原脚本执行的结果一样。 我们还可以以tbash3.sh为示例。 用以下命令来执行该脚本: [nsvc@localhost other]$ bash tbash3.sh tbash3.sh: line 1: abc: No such file or directory hello abc [nsvc@localhost other]$ sh tbash3.sh tbash3.sh: line 1: abc: No such file or directory [nsvc@localhost other]$ bash --posix tbash3.sh tbash3.sh: line 1: abc: No such file or directory "bash tbash3.sh"表示使用bash来作为脚本解释器来执行tbash3.sh。同样,也可以使用如”sh脚本名“这样的命令,来用sh作为脚本解释器。 从结果可以看出,/bin/bash--posix与/bin/sh的执行结果相同。总结起来,sh跟bash的区别,实际上是bash有没开启posix模式的区别。遵守posix规范,可能包括,”当某行代码出错时,不继续往下执行。“ 最后加上一点说明,每个脚本开头都使用"#!",#!实际上是一个2字节魔法数字,这是指定一个文件类型的特殊标记,在这种情况下,指的就是一 个可执行的脚本。在#!之后,接一个路径名,这个路径名指定了一个解释脚本命令的程序,这个程序可以是shell,程序语言或者任意一个通用程序。 ##########sample shell 数字的比较
shell中数字大小的比较
示例脚本:
#!/bin/bash
if [ $1 -gt $2 ]
then echo "参数$1大于参数$2"
else echo "参数$1小于参数$2"
fi
数字判断一些命令:
#-gt是大于
#-lt是小于
#-eq是等于
#-ne是不等于
#-ge是大于等于
#le是小于等于
【小数及整数之前的比较】
示例脚本:
|
说明:
可以使用的比较符号:
>
<
==
>=
<=
如果双引号内执行结果为真,c的值就是1,否则c的值就是0.
注意:这里一定一定要注意的是,这个比较结果就是0或1,而不是代表true或false,因而不能用于if后的条件判断!切记切记!
###如果出现引用 变量 出现 换行,可以加一个 “ 号,相当与2个 ""
result=`echo ""$QUERYRES_B" > "$QUERYRES"" | bc`
echo $result
if [ $result -eq 0 ]; then
sqlplus -S $LOGIN_ID <<EOF
insert into aio_nodg_info values ('${db}');
commit;
exit;
EOF