Shell学习笔记,shell脚本

时间:2019-05-11 09:46来源:计算机教程
CREATE FUNCTION dbo.check_number(/*验证一字符串类型是否为整型数值类型*/@checkTmp VARCHAR(100))RETURNS BITBEGINDECLARE @tmp BITIF LEFT(@checkTmp, 1) = '-'SET @checkTmp = SUBSTRING(@checkTmp, 2, LEN(@checkTmp))IF (PATINDEX('%
 CREATE FUNCTION dbo.check_number
(
/*验证一字符串类型是否为整型数值类型*/
@checkTmp VARCHAR(100)
)
RETURNS BIT
BEGIN
DECLARE @tmp BIT
IF LEFT(@checkTmp, 1) = '-'
SET @checkTmp = SUBSTRING(@checkTmp, 2, LEN(@checkTmp))
IF (PATINDEX('%[^0-9-]%', @checkTmp) = 0
AND CHARINDEX('-', @checkTmp) <= 1
AND @checkTmp NOT IN ('.', '-', ' ', '^')
AND LEN(@checkTmp)>0
AND @checkTmp NOT LIKE '%-%')
SET @tmp = 1
ELSE
SET @tmp = 0
RETURN @tmp
END
GO

/*数据验证*/
SELECT '878' [测试数值],dbo.check_number('999') [测试返回值];
SELECT 'testData' [测试数值],dbo.check_number('abc') [测试返回值];
SELECT '8-8' [测试数值],dbo.check_number('9 9') [测试返回值];
SELECT '8.9' [测试数值],dbo.check_number('$9.9') [测试返回值];
SELECT 'maomao365.com' [测试数值],dbo.check_number('maomao365.com') [测试返回值];
go
drop function check_number

4. 两个文件比较

1)文件1 -nt 文件2:判断文件1的修改时间是否比文件2的新

2)文件1 -ot 文件2:判断文件1的修改是否是否比文件2的旧

3)文件1 -ef 文件2:判断文件1是否和文件2的lnode号一致,可以理解为两个文件是否为同一个文件。这个判断用于判断硬链接是很好的方法。

示例:

[[email protected] ~]# [ /root/install.log -nt /root/install.log.syslog ] && echo yes || echo no
yes
[[email protected] ~]# [ /root/install.log -ot /root/install.log.syslog ] && echo yes || echo no
no
[[email protected] ~]# [ /root/install.log -ef /root/install.log.syslog ] && echo yes || echo no
no

 

例:
实现原理:判断 是否包含特殊字符,是否全部为0-9的自然数组成

2. 判断文件类型参数

1)-d 文件:判断该文件是否存在,并且是否为目录文件

2)-e 文件:判断文件是否存在

3)-f 文件:判断文件是否存在,并且是否为普通文件

4)-s 文件:判断文件是否存在,并且是否为非空

5)其他文件类型判断:

-b 块设备文件;-c 字符设备文件;-L 符号链接文件; -p 管道文件;-S 套接字文件

示例:

[[email protected] ~]# [ -d /root ] && echo yes || echo no
yes
[[email protected] ~]# [ -e /root/install.log ] && echo yes || echo no
yes
[[email protected] ~]# [ -f /root/install.log ] && echo yes || echo no
yes
[[email protected] ~]# [ -s /root/install.log ] && echo yes || echo no
yes

 


Shell学习笔记,shell脚本

摘要:
下文将制作一个isnumber验证整型的函数,供在sql脚本中做数值判断,如下所示:

1. 判断格式

1) test 参数 文件

例: test -e /root/install.log

2) [ 参数 文件 ]  -- 推荐使用

例: [ -e /root/install.log ]

注意:中括号后面和前面需要有空格

编辑:计算机教程 本文来源:Shell学习笔记,shell脚本

关键词: