在SQLServer上得到客户端信息(操作的数据库名,计算机名,用户名,网卡物理地址,IP地址,程序名)
create proc p_getlinkinfo
@dbname sysname=null,--要查询的数据库名,默认查询所有数据库的连接信息
@includeip bit=0--是否显示IP地址,因为查询IP地址比较费时,所以增加此控制
as
declare @dbid int
set @dbid=db_id(@dbname)
create table #tb(id int identity(1,1),dbname sysname,hostname nchar(128),loginname nchar(128),net_address nchar(12),net_ip nvarchar(15),prog_name nchar(128))
insert into #tb(hostname,dbname,net_address,loginname,prog_name)
select distinct hostname,db_name(dbid),net_address,loginame,program_name from master..sysprocesses
where hostname<>'' and (@dbid is null or )
if @includeip=0 goto lb_show --如果不显示IP地址,就直接显示
declare @sql varchar(500),@hostname nchar(128),@id int
create table #ip(hostname nchar(128),a varchar(200))
declare tb cursor local for select distinct hostname from #tb
open tb
fetch next from tb into @hostname
while @@fetch_status=0
begin
set @sql='ping '+@hostname+' -a -n 1 -l 1'
insert #ip(a) exec master..xp_cmdshell @sql
update #ip set where hostname is null
fetch next from tb into @hostname
end
update #tb set net_ip=left(a,patindex('%:%',a)-1)
from #tb a inner join (
select hostname,a=substring(a,patindex('Ping statistics for %:%',a)+20,20) from #ip
where a like 'Ping statistics for %:%') b on a.hostname=b.hostname
lb_show:
select id,数据库名=dbname,客户机名=hostname,用户名=loginname
,网卡物理地址=net_address,IP地址=net_ip,应用程序名称=prog_name from #tb
GO
//显示所有本机的连接信息:
exec p_getlinkinfo
//显示所有本机的连接信息,包含ip地址:
exec p_getlinkinfo @includeip=1
//显示连接指定数据库的信息:
exec p_getlinkinfo @dbname=表名,@includeip=1
B. SqlServer更改机器名后如何修改数据库的机
在安装好后服务器,并安装SQL Server软件后,如果需要修改主机名,除了修改注册表里面的东西外,还需要通过如下方式修改SQL Server认到的主机名
sp_dropserver'PCName1'
sp_addserver'PCName2','local'
本地的主机名也可以通过select * from sys.servers 来查看。
更详细的信息
--.
--.:
--,forexample,ifitisa
--,sp_dropservermaygenerate
--anerrorsimilartothis:
--Server:Msg15190,Level16,State1,Proceresp_dropserver,Line44
--'SERVER1'.
--Toresolvetheerror,.
--Ifreplicationisinstalled,
--runningthesp_dropserverstoredprocere.
--Sidenote:
--
--_addserverwhenrenamingaserver.Thecorrectsyntaxis
--execsp_addserver'<NEWSERVERNAME>','local'
--
--,.
--Ifyoutrytoreplicatefrom(andpossiblyto)thisserver,
--withanIDof0whichwon'tbethere.
--andbombs.
execsp_dropserver<oldservername>
go
execsp_addserver<newservername>','local'
go
--:Ifthisisn'tdone,thejobson
--theservercan'tbeedited,
updatemsdb.dbo.sysjobs
setoriginating_server='<newservername>'
whereoriginating_server='<oldservername>'
go
C. SQL 服务器名称
1、服务器桌面鼠标右击[计算机]图标,从弹出的快捷菜单中选择"属性"
D. SQL数据库的名字怎么看
首先确认数据库服务器功能开启没有。
服务里面找到sql
server
agent
(mssqlserver)
,启动。
本机ip地址一般都是127.0.0.1,至于名字,一般都是装数据库时实例的名字
E. 怎样获取数据库所在计算机主机名
--楼下的回答有问题如果楼主安装的时候改了实例名
就是楼主的方法
而且是必须如果是默认的实例名
那就是直接计算机名就可以了
F. SQL怎么实现:返回服务器当前的主机名
@@SERVERNAME 返回运行SQL Server 2000本地服务器的名称。
@@REMSERVER 返回登录记录中记载的远程SQL Server服务器的名称。
在查询分析器(2000)或查询窗口(2005)中输入
select @@Servername或@@REMSERVER就可以查看到了。
G. 怎么获取本机 sql server 2000的服务器名称 和端口号
打开SQL的服务管理器,上面的服务后面的名字就是SQLSERVER服务器的名字。
也可以在SQL的服务管理器中运行下列命令:
服务器名称<%=Environment.OSVersion.ToString()%>
端口<%=Request.ServerVariables["SERVER_PORT"]%>
H. 我刚安装了SQL数据库,请问主机名怎么找呀它默认的主机名老连接不上
连接不上,有以下几个原因:
1、网络不通,解决方法:你先访问一下那台机器,如果可以访问,就可以连接上
2、有的机器即使一切都正常,还是连接不上,我碰到过几次。解决方法:连接时不要用机器名,用IP地阯,如果还是不行,说明SQL装的有问题