SQL中与IP相关的常见问题

王朝mssql·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航