当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 根据进程号获取该进程所在客户端的ip地址

MSSQL
在SQL Server中建立定时任务,处理时间超过一天的记录
推荐:监控数据库性能的SQL语句汇总
SQL Server常用到的几个设置选项
SQL server 2000存储过程
sql server行转列问题终极解决
专家在线:SQL Server块日志恢复
通过内存配置来优化SQL Server的性能
为SQL Server构造灵活可靠的安全门
剖析SQL Server数据库扩展存储过程
专家在线:SQL Server的数据清理技术
SQL Server 2005中的所有权链
利用SQL Server数据库快照形成报表
SQL技巧:探索用户自定义数据类型
保护SQL服务器的安全-用户识别问题
一些SQL Server的应用实例
SQLSERVER中,数据库同步的实现
深入理解SQL Server 中的错误处理
三种SQL分页法效率分析
sql server 2005中的except和INTERSECT运算
SQL 视图效率和连接超时设置

MSSQL 中的 根据进程号获取该进程所在客户端的ip地址


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 115 ::
收藏到网摘: n/a

create PROCEDURE dbo.SP_SPIDtoIP @SPID int
AS
-- SPID to MAC
-- lj
DECLARE @MAC as varchar(12)
SELECT @MAC = NET_ADDRESS FROM master..sysprocesses WHERE SPID = @SPID
-- MAC to IP
DECLARE @MACDisplay as varchar(18)
DECLARE @IP as varchar(15)
CREATE TABLE #temp (OUTPUT varchar(255) null)
SET NOCOUNT ON
INSERT INTO #temp EXEC master..xp_cmdshell 'arp -a'
if @@error<>0
begin
RAISERROR ('The level for job_id:%d should be between %d and %d.', 16, 1)
--ROLLBACK TRANSACTION
end
SELECT @MACDisplay = LEFT(@MAC, 2) + '-' + SUBSTRING(@MAC, 3, 2) + '-' + SUBSTRING(@MAC, 5, 2) + '-' + SUBSTRING(@MAC, 7, 2) + '-' + SUBSTRING(@MAC, 9, 2) + '-' + SUBSTRING(@MAC, 11, 2) SELECT @IP = SUBSTRING(output, 3, 15) FROM #temp WHERE output LIKE '%' + @MACDisplay + '%'
-- Resolve the IP
--DECLARE @CMD as varchar(100)
--select @CMD = 'master..xp_cmdshell "ping -a ' + @IP + '"'
--exec (@CMD)
DROP TABLE #temp
SET NOCOUNT OFF
GO