sql server 和 oracle 中,ip与数字互转
来源:互联网 发布:软件创新设计方案 编辑:程序博客网 时间:2024/05/01 02:56
(一)Oracle中:
(1) IP转为数字:
- create or replace function ip2number(ip varchar2)
- return number
- is
- ip_num_hex varchar2(80);
- begin
- if (regexp_like(ip, '^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$')) then
- ip_num_hex := lpad(trim(to_char(regexp_replace(ip, '^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$', '\1'), 'XX')),2,'0') ||
- lpad(trim(to_char(regexp_replace(ip, '^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$', '\2'), 'XX')),2,'0') ||
- lpad(trim(to_char(regexp_replace(ip, '^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$', '\3'), 'XX')),2,'0') ||
- lpad(trim(to_char(regexp_replace(ip, '^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$', '\4'), 'XX')),2,'0');
- return to_number(ip_num_hex, 'XXXXXXXX');
- else
- return -1;
- end if;
- exception
- when others then
- return -99999999999;
- end;
- select ip2number('169.254.55.6') from dual;
- IP2NUMBER('169.254.55.6')
- -------------------------
- 2852009734
(2) 数字转为IP:
- create or replace function number2ip(num number)
- return varchar2 is
- ip_num_hex varchar2(8);
- begin
- ip_num_hex := lpad(trim(to_char(num, 'XXXXXXXX')), 8, '0');
- return to_number(substr(ip_num_hex, 1, 2), 'XX') || '.' ||
- to_number(substr(ip_num_hex, 3, 2), 'XX') || '.' ||
- to_number(substr(ip_num_hex, 5, 2), 'XX') || '.' ||
- to_number(substr(ip_num_hex, 7, 2), 'XX');
- exception
- when others then
- dbms_output.put_line(sqlerrm);
- return null;
- end;
- select number2ip(2852009734) from dual;
- NUMBER2IP(2852009734)
- --------------------------------------------------------------------------------
- 169.254.55.6
(二)SQL Server中:
(1) IP转为数字:
- if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_IP2Int]') and xtype in (N'FN', N'IF', N'TF'))
- drop function [dbo].[f_IP2Int]
- GO
- /*--字符型 IP 地址转换成数字 IP
- /*--调用示例
- select dbo.f_IP2Int('192.168.0.11')
- select dbo.f_IP2Int('12.168.0.1')
- --*/
- CREATE FUNCTION f_IP2Int(
- @ip char(15)
- )RETURNS bigint
- AS
- BEGIN
- DECLARE @re bigint
- SET @re=0
- SELECT @re=@re+LEFT(@ip,CHARINDEX('.',@ip+'.')-1)*ID
- ,@ip=STUFF(@ip,1,CHARINDEX('.',@ip+'.'),'')
- FROM(
- SELECT ID=CAST(16777216 as bigint)
- UNION ALL SELECT 65536
- UNION ALL SELECT 256
- UNION ALL SELECT 1)A
- RETURN(@re)
- END
- GO
(2) 数字转为IP:
- if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_Int2IP]') and xtype in (N'FN', N'IF', N'TF'))
- drop function [dbo].[f_Int2IP]
- GO
- /*--数字 IP 转换成格式化 IP 地址
- /*--调用示例
- select dbo.f_Int2IP(3232235531)
- select dbo.f_Int2IP(212336641)
- --*/
- CREATE FUNCTION f_Int2IP(
- @IP bigint
- )RETURNS varchar(15)
- AS
- BEGIN
- DECLARE @re varchar(15)
- SET @re=''
- SELECT @re=@re+'.'+CAST(@IP/ID as varchar)
- ,@IP=@IP%ID
- from(
- SELECT ID=CAST(16777216 as bigint)
- UNION ALL SELECT 65536
- UNION ALL SELECT 256
- UNION ALL SELECT 1)a
- RETURN(STUFF(@re,1,1,''))
- END
0 0
- sql server 和 oracle 中,ip与数字互转
- IP 数字 互转 SQL server
- C#中IP地址与数字之间的互转
- Sql server 与 Oracle
- Sql Server 与 Oracle
- HOW TO:在 SQL Server 中设置与 Oracle 间的链接服务器和进行疑难解答
- sql server与oracle的互联
- 浅析SQL Server与Oracle区别(转)
- 转 SQL server 与Oracle开发比较
- 转-浅析SQL Server与Oracle区别
- Oracle中INSTR函数与SQL Server中CHARINDEX函数
- JAVA IP地址与数字互转
- Sql Server和Oracle转置问题
- sql server和oracle中关于null和''的问题
- 关于Oracle与SQL Server中数据迁移的办法
- sql server 与oracle 中字段类型的对应
- SQL Server和Oracle日期与字符串之间的转换
- oracle与sql server区别
- hibernate 中关联关系映射中inverse 和cascade的理解
- uva 674Coin Change
- 今天开始学习Android开发
- 记几个IOS工具网站
- Leetcode 线性表 Merge Two Sorted Lists
- sql server 和 oracle 中,ip与数字互转
- 嵌入式数据库移植Sqlite3
- 修改Myeclipse工作空间
- java使用axis调用WebService简单示例
- extjs api类(或组件)的名字相关说明
- ant的使用
- python 时间字符串转为时间戳
- 暴力破解UltraEdit v21 无需注册
- C++ Java要点记录