有SQL语句可以获得数据库服务器IP的么?

Liyingyue_FFS 2008-08-04 10:03:47
如题
...全文
198 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
Well 2008-08-04
  • 打赏
  • 举报
回复
就用xp_cmdshell执行dos命令。。。
hyqwan11112 2008-08-04
  • 打赏
  • 举报
回复
学习了!
忆轩辕 2008-08-04
  • 打赏
  • 举报
回复
如果使用客户端看的话需要知道数据库服务器的机器名

exec marster.dbo.xp_cmdshell 'ping 机器名'
忆轩辕 2008-08-04
  • 打赏
  • 举报
回复


exec master.dbo.xp_cmdshell 'ipconfig'
三下鱼 2008-08-04
  • 打赏
  • 举报
回复




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



=====
以上都是转载别处的
中国风 2008-08-04
  • 打赏
  • 举报
回复
create table #(Col nvarchar(100))
insert # exec xp_cmdshell 'ping 機器名 '

select top 1
substring(Col,charindex('[',Col)+1,charindex(']',Col)-charindex('[',Col)-1)
from
#
where
len(COL)>1




中国风 2008-08-04
  • 打赏
  • 举报
回复
用 xp_cmdshell 執行DOS命令

34,593

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧