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是小于等于   


【小数及整数之前的比较】


示例脚本:



​a=1.6
b=6.1
c=`echo "$a > $b" | bc`​


说明:


可以使用的比较符号:

>

<

==

>=

<=

如果双引号内执行结果为真,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