将作为字符串保存的IP地址变为二进制数值
来源:互联网 发布:帝国时代 知乎 编辑:程序博客网 时间:2024/06/07 10:27
CREATE FUNCTION dbo.IPAddrStr2Bin(@strIP varchar(15), @Validate bit = 1)
RETURNS binary(4)
AS
BEGIN
IF @Validate = 1
BEGIN
-- only digits and dots
IF @strIP LIKE '%[^.0-9]%' RETURN (NULL)
-- number of dots must be 3
IF LEN(@strIP) - LEN(REPLACE(@strIP, '.', '')) != 3 RETURN (NULL)
-- all octets must be specified
IF @strIP NOT LIKE '%_%.%_%.%_%.%_%' RETURN (NULL)
END
DECLARE @oct1 binary(1),
@oct2 binary(1),
@oct3 binary(1),
@oct4 binary(1)
SET @oct1 = CAST(CAST(LEFT(@strIP, CHARINDEX('.', @strIP) - 1) AS int) AS
binary(1))
SET @oct2 = CAST(CAST(SUBSTRING(@strIP, CHARINDEX('.', @strIP) + 1,
CHARINDEX('.', @strIP, CHARINDEX('.', @strIP) + 1) - CHARINDEX('.', @strIP)
- 1) AS int) AS binary(1))
SET @oct3 = CAST(CAST(SUBSTRING(@strIP, CHARINDEX('.', @strIP,
CHARINDEX('.', @strIP) + 1) + 1, (LEN(@strIP) - CHARINDEX('.',
REVERSE(@strIP)) + 1) - (CHARINDEX('.', @strIP, CHARINDEX('.', @strIP) + 1))
- 1) AS int) AS binary(1))
SET @oct4 = CAST(CAST(RIGHT(@strIP, LEN(@strIP) - (LEN(@strIP) -
CHARINDEX('.', REVERSE(@strIP)) + 1)) AS int) AS binary(1))
IF @Validate = 1
BEGIN
IF NOT(
(@oct1 BETWEEN 0x01 AND 0xFF) AND
(@oct2 BETWEEN 0x00 AND 0xFF) AND
(@oct3 BETWEEN 0x00 AND 0xFF) AND
(@oct4 BETWEEN 0x00 AND 0xFF)
) RETURN(NULL)
END
RETURN (@oct1 + @oct2 + @oct3 + @oct4)
END
GO
使用例子:
SELECT dbo.IPAddrStr2Bin('172.29.23.2', 0)
对于 SQL Server较早的版本,你可以抽出代码,然后直接使用,或者创建如下所示的存储过程:
CREATE PROCEDURE dbo.spIPAddrStr2Bin
@strIP varchar(15),
@binIP binary(4) OUTPUT,
@Validate bit = 1
AS
IF @Validate = 1
BEGIN
-- only digits and dots
IF @strIP LIKE '%[^.0-9]%' RETURN (NULL)
-- number of dots must be 3
IF LEN(@strIP) - LEN(REPLACE(@strIP, '.', '')) != 3 RETURN (NULL)
-- all octets must be specified
IF @strIP NOT LIKE '%_%.%_%.%_%.%_%' RETURN (NULL)
END
DECLARE @oct1 binary(1),
@oct2 binary(1),
@oct3 binary(1),
@oct4 binary(1)
SET @oct1 = CAST(CAST(LEFT(@strIP, CHARINDEX('.', @strIP) - 1) AS int) AS
binary(1))
SET @oct2 = CAST(CAST(SUBSTRING(@strIP, CHARINDEX('.', @strIP) + 1,
CHARINDEX('.', @strIP, CHARINDEX('.', @strIP) + 1) - CHARINDEX('.',
@strIP) - 1) AS int) AS binary(1))
SET @oct3 = CAST(CAST(SUBSTRING(@strIP, CHARINDEX('.', @strIP,
CHARINDEX('.', @strIP) + 1) + 1, (LEN(@strIP) - CHARINDEX('.',
REVERSE(@strIP)) + 1) - (CHARINDEX('.', @strIP, CHARINDEX('.', @strIP) +
1)) - 1) AS int) AS binary(1))
SET @oct4 = CAST(CAST(RIGHT(@strIP, LEN(@strIP) - (LEN(@strIP) -
CHARINDEX('.', REVERSE(@strIP)) + 1)) AS int) AS binary(1))
IF @Validate = 1
BEGIN
IF NOT(
(@oct1 BETWEEN 0x01 AND 0xFF) AND
(@oct2 BETWEEN 0x00 AND 0xFF) AND
(@oct3 BETWEEN 0x00 AND 0xFF) AND
(@oct4 BETWEEN 0x00 AND 0xFF)
) RETURN(NULL)
END
SET @binIP = @oct1 + @oct2 + @oct3 + @oct4
GO
使用例子:
DECLARE @binIP binary(4)
EXEC dbo.spIPAddrStr2Bin '172.29.23.2', @binIP OUTPUT, 0
PRINT @binIP
注意: 如果你不需要或不想验证自己的字符串IP地址,可以完全删掉对它们进行处理的代码。
- 将作为字符串保存的IP地址变为二进制数值
- 如何将作为字符串保存的IP地址变为二进制数值?
- 字符串IP地址和二进制IP地址的转换
- awk:将IP地址转为数值
- C++实现将十进制的ip地址转换为二进制ip地址
- 将IP地址转换为二进制
- 将IP地址转换为二进制表示
- C# 将二进制字符串保存到本地
- Java将图片作为二进制进行保存和读取
- sql将查询出的数值变为中文
- MySQL如何有效的存储IP地址及字符串IP和数值之间如何转换
- 字符串IP地址转换成IP数值函数
- 字符串IP地址转换成IP数值函数
- 将字符串表示的IP地址转变为整形表示
- C++将一个数值转化为二进制字符串
- 一个将u_long型的IP地址转化成字符串形式的IP地址方法
- 获取地址栏的IP和端口,将URL地址图片转换为二进制
- float和double的数值怎么保存在二进制中
- 创新工场O2O项目布丁六款生活类应用简评
- SQL Server 6.5 配置使用要点
- 在O(1)时间内返回栈的最小值
- 解决MSSQL占用过多内存的简单方法
- VC使用MSXML解析XML文档
- 将作为字符串保存的IP地址变为二进制数值
- SQL Server数据库崩溃时恢复方式
- gcc中的-finput-charset和-fexec-charset开关
- SQL Server提升权限相关命令及防范
- POJ 3842 An Industrial Spy
- linux + eclipse调试ffmpeg
- 在本机 Android 应用程序中载入 Google Maps API 网站
- Delphi中单链表操作
- Debian wine foxmail7.0安装