打印本文 打印本文 关闭窗口 关闭窗口
SQL中与IP相关的常见问题
作者:武汉SEO闵涛  文章来源:敏韬网  点击数1098  更新时间:2007/11/14 11:02:30  文章录入:mintao  责任编辑:mintao

1:得到客户端的IP地址
/************* IP  **************/
declare @ip varchar(20),@hst varchar(20),@sql varchar(100)
declare @str varchar(100)
set @str=''''PING ''''+Host_Name()
create table #tmp(aa varchar(200))
insert #tmp exec master..xp_cmdshell @str
select top 1 @ip = replace(left(aa,charindex('''':'''',aa)-1),''''Reply from '''','''''''')
   from #tmp where aa like ''''reply from %:%''''
drop table #tmp
select @ip


2:得到网卡的物理地址
create table #tb(re varchar(255))
insert into #tb exec master..xp_cmdshell ''''ipconfig /all''''

select 网卡物理地址=substring(re,charindex('''':'''',re)+1,255) from #tb where re like ''''%Physical Address. . . . . . . . . :%''''

drop table #tb

3:    将IP地址段转成每三位用点号分开    
create function getIP(@a varchar(15))
returns varchar(15)
As
begin
declare @s varchar(15)
set @s = ''''''''
while charindex(''''.'''',@a) > 0
begin
 set @s = @s + right(''''000'''' + left(@a,charindex(''''.'''',@a)),4)
 set @a = right(@a,len(@a)-charindex(''''.'''',@a))
end
set @s = @s + right(''''000'''' + @a,3)
return @s
end

/*
Select dbo.getIP(''''202.1.110.2'''')
---------------
202.001.110.002

(所影响的行数为 1 行)
*/
--drop function getIP

打印本文 打印本文 关闭窗口 关闭窗口