select * from sp_who的解决方案

 更新时间:2009年04月15日 22:25:54   作者:  
sql server中提供很多有用的系统存储过程,但是我们都知道,存储过程的结果集是不能用select来过滤的,也就是说select * from sp_who where [dbname] = 'xxx';这样的语句是执行不过。下面介绍两种方法来解决这个问题
方法一:使用临时表。
首先创建一个与sp_who相同字段的临时,然后用insert into 方法赋值,这样就可以select这个临时表了。具体代码如下:
create table #TempTable(spid int,ecid int,status varchar(32),loginname varchar(32),hostname varchar(32),blk int,dbname varchar(32),cmd varchar(32),request_id int);
insert into #TempTable
exec sp_who;
select * from #TempTable where [dbname] = 'master';
drop table #TempTable
方法二:使用OPENROWSET
代码如下:
select * from openrowset('SQLOLEDB','servername';'userName';'password','sp_who') where [dbname] = 'master';
执行上面这个语句,如果提示:SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息。
说明你没有配置 'Ad Hoc Distributed Queries' ,按如下方法配置
启用Ad Hoc Distributed Queries:
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
然后就可以运行上面的代码了。
使用完成后,如果想关闭Ad Hoc Distributed Queries,执行如下代码:
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure

相关文章

  • SQLServer存储过程中事务的使用方法

    SQLServer存储过程中事务的使用方法

    这篇文章主要介绍了SQLServer存储过程中事务的使用方法,简短的代码带大家更好的学习使用SQLServer存储过程中事务,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • MSSQL自动重建出现碎片的索引的方法分享

    MSSQL自动重建出现碎片的索引的方法分享

    无论何时对基础数据执行插入、更新或删除操作,SQL Server 数据库引擎都会自动维护索引。随着时间的推移,这些修改可能会导致索引中的信息分散在数据库中(含有碎片)。当索引包含的页中的逻辑排序(基于键值)与数据文件中的物理排序不匹配时,就存在碎片。碎片非常多的索引可能会降低查询性能,导致应用程序响应缓慢。
    2014-06-06
  • Sqlserver 表类型和表变量介绍

    Sqlserver 表类型和表变量介绍

    这篇文章介绍了Sqlserver 表类型和表变量,有需要的朋友可以参考一下
    2013-09-09
  • sqlserver 脚本和批处理指令小结

    sqlserver 脚本和批处理指令小结

    sqlserver 脚本和批处理指令小结,学习sqlserver的朋友可以收藏下
    2012-05-05
  • Sql中的like的用法及示例操作

    Sql中的like的用法及示例操作

    SQL中一个强大而灵活的条件查询操作——LIKE关键字的用法,作为SQL语句中的一部分,LIKE关键字用于模糊查询,使得我们能够更灵活地检索数据库中符合特定模式的数据,下面给大家介绍Sql中的like的用法,感兴趣的朋友跟随小编一起看看吧
    2024-05-05
  • sql索引失效的情况以及超详细解决方法

    sql索引失效的情况以及超详细解决方法

    众所周知索引并不是时时都会生效的,下面这篇文章主要给大家介绍了关于sql索引失效的情况以及超详细解决方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • SQLServer代理中如何给操作员发送事件警报邮件

    SQLServer代理中如何给操作员发送事件警报邮件

    在所有的SQL Server系统中至少要配置一个操作员,这会保证对于大多数严重错误,一些特定的提醒会发给你,当然,发送邮件警报的话需要SQL Server能发送邮件警报,另外,当警报触发时可以执行作业意味着你可以通过自动化操作修正很多常规错误,而不需要每次都人为干预错误发生
    2025-03-03
  • 数据库使用之union、union all、各种join的用法区别解析

    数据库使用之union、union all、各种join的用法区别解析

    这篇文章主要介绍了SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,包括innerjoin和leftjoin的区别,以及联表条件的写法,需要的朋友可以参考下
    2025-02-02
  • SQL server数据库declare和set用法技巧小结

    SQL server数据库declare和set用法技巧小结

    这篇文章主要给大家介绍了关于SQL server数据库declare和set用法技巧的相关资料,在SQL Server中,DECLARE用于声明变量和存储过程中的参数,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • SQL 查询和删除重复字段数据的方法

    SQL 查询和删除重复字段数据的方法

    这篇文章介绍了SQL 查询和删除重复字段数据的方法,有需要的朋友可以参考一下
    2013-08-08

最新评论