当我登录sql server时。我看到许多数据库,但我没有访问某些数据库。所以我只想列出使用linkedname访问数据库的列表。
select name FROM sys.sysdatabases WHERE HAS_DBACCESS(name) = 1我在本地运行这段代码,它正在工作。但我想运行这个代码
select name FROM [linkedname].sys.sysdatabases WHERE HAS_DBACCESS(name) = 1它不起作用。
发布于 2019-07-02 11:21:47
[linkedname].sys.sysdatabases将引用数据库 linkedname,而不是服务器。
您需要使用4部分命名LinkedServerName.DatabaseName.SchemaName.ObjectName。对于您的例子,这将是:[linkedname].master.sys.sysdatabases
但是,因为(正如Dan所指出的)这是一个链接查询,所以HAS_DBACCESS将在本地运行。您可以通过使用OPENQUERY来解决这个问题。
SELECT [name]
FROM OPENQUERY(linkedname,N'SELECT [name] FROM master.sys.sysdatabases WHERE HAS_DBACCESS(name) = 1;'); https://stackoverflow.com/questions/56851300
复制相似问题