SQL中与IP相关的常见问题
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
- 最新文章
- 给SQL Server传送数组参数的变通办法[02-28]
- 微软工程师讲解SQL server阻塞[02-28]
- SQL Server 2000中的触发器使用[02-28]
- 通用SQL数据库查询语句精华使用简介[02-28]
- 修复断电等损坏的SQL数据库[02-28]
- SQL Server中利用存储过程来高性能地进行分页[02-28]
- 相关文章
- 给SQL Server传送数组参数的变通办法[02-28]
- 微软工程师讲解SQL server阻塞[02-28]
- SQL Server 2000中的触发器使用[02-28]
- 通用SQL数据库查询语句精华使用简介[02-28]
- 修复断电等损坏的SQL数据库[02-28]
- SQL Server中利用存储过程来高性能地进行分页[02-28]
