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

Shell基础:变量类型 & 运算符

2016-08-10 23:05 721 查看

Shell变量

Shell支持三种类型的变量

用户自定义变量:用户自定义的变量,变量名以英文字母或下划线开头,区分大小写。

位置变量:根据位置传递参数给脚本的变量,默认支持9个位置变量 $1,$2,$3...$9

预定义变量: 预定义的特殊变量,只能使用,不能修改

用户自定义变量

#定义变量:变量名=变量值, 可以使用"常量/其他变量/命令执行结果"赋值
var1='test var'
var2="test variable $var1"
var3=`date`

#单引号中将$就当作$, 不识别$为特殊符号,不能引用起他变量
echo 'the price is $100'

#双引号中可以通过$来引用变量,但无法解析转义符号,要解析转义符和字体格式需要在echo命令前加-e 参数
echo "test /n test"
echo -e "test /n test"

#`` 反引号可以运行完其中的脚本命令然后赋值给相应的变量,如下执行结果会打印出123.sql的结果和当前日期
str=`cat 123.sql`
strdate=`date`
echo "$str $date`

#使用变量:$变量名
echo "$var $var1"

#变量后直接连接字符串需要用{}隔开使得变量可识别
echo "测试变量${var}test"

# 清除变量
unset var1


位置变量

新建根据参数执行数据库命令脚本

#!/bin/bash
#mysql.sh

conn="/usr/local/mysql/bin/mysql -uroot -p123"

case $1 in
select)
sql="select * from test.user"
;;
delete)
sql="delete from test.user where id =$2"
;;
insert)
sql="insert into test.user(uname,psd) values('$2','$3')"
;;
update)
sql="update test.user set uname='$3', psd='$4' where id='$2'
;;
esac

$conn -e "$sql"


运行脚本,以空格为分隔符输入不同个数的参数

#显示test数据库下user表的所有数据
./mysql.sh select
#删除指定id的用户
./mysql.sh delete 4
#插入新用户
./mysql.sh insert newuser newpsd
#更新id=2用户属性
./mysqlsh update 2 newuser2 newpsd2


预定义变量  

Shell脚本支持四种形式的预定义变量:

$#: 所有位置参数的个数

$*: 所有位置参数的内容

$0: 当前执行的脚本名(程序或者是进程名)

$?: 上一条命令执行的状态,为0代表执行成功,为其他数字(eg:127...)代表执行失败

!/bin/bash
#test pre-defined bash variable
echo "当前脚本的位置参数有${#}个"
echo "当前正在执行的脚本名称是: $0"

if[ [ $? == 0 ] ];then
echo "上条命令执行成功"
else
echo  "上条命令执行失败"
fi

for i in $*; do
echo "位置变量为 $i"
done


运算符

Shell是脚本语言,变量没有区分类型,程序在实际运行的时候根据上下文做类型判断,默认的类型是String,如果需要把变量看作Int类型来进行加减乘除运算,需要采用特殊语法。

$((变量1运算符1变量2运算符2变量3)) : 此种方式用的较多, eg: $((2+3+4)); $((2*3))

expr 变量1 运算符 变量2 运算符 变量3 :变量和运算符之间一定要用空格隔开,此种方法比较少用, 并且乘法要用转移\*, eg: expr 2 + 3 + 4; expr 2 \* 3

Shell常用运算符







/

%
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐