SQL Server 2016里的sys.dm_exec_input_buffer的问题
2016-04-19 00:00
666 查看
我们都知道DBCC命令有点尴尬,因为你不能在T-SQL查询里调用它们,你也不能关联它们的输出到其它DMV/DMF。例如你想为每个用户会话返回最后一个执行的SQL语句....
sys.dm_exec_input_buffer
在SQL Server 2016里,事情就变得简单多,因为微软为你提供了一个新DMFsys.dm_exec_input_buffer,它和DBCC INPUTBUFFER一样做同样的工作。
使用sys.dm_exec_input_buffer非常简单:这个DMF需要2个输入参数――会话和指定会话的请求id。下面代码展示了调用新函数的简单例子。
但你可以做更复杂的事情,像用CROSS APPLY运算符与其它DMV关联信息。我们来看下面的代码。
如你在这里看到的,这个查询对于所有当前执行的查询,返回所有提交的SQL语句。很简单,是不是?
SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(中)
sys.dm_exec_input_buffer
在SQL Server 2016里,事情就变得简单多,因为微软为你提供了一个新DMFsys.dm_exec_input_buffer,它和DBCC INPUTBUFFER一样做同样的工作。
使用sys.dm_exec_input_buffer非常简单:这个DMF需要2个输入参数――会话和指定会话的请求id。下面代码展示了调用新函数的简单例子。
SELECT * FROM sys.dm_exec_input_buffer(55, 0) GO
但你可以做更复杂的事情,像用CROSS APPLY运算符与其它DMV关联信息。我们来看下面的代码。
SELECT r.session_id, ib.event_info FROM sys.dm_exec_requests r JOIN sys.dm_exec_sessions s ON s.session_id = r.session_id CROSS APPLY sys.dm_exec_input_buffer(r.session_id, r.request_id) ib WHERE s.is_user_process = 1 GO
如你在这里看到的,这个查询对于所有当前执行的查询,返回所有提交的SQL语句。很简单,是不是?
您可能感兴趣的文章:
SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(上)SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(中)
相关文章推荐
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- 网马生成器 MS Internet Explorer XML Parsing Buffer Overflow Exploit (vista) 0day
- jQuery根据ID获取input、checkbox、radio、select的示例
- VBS中Run和Exec的区别
- css样式之区分input是按钮还是文本框的方法第1/4页
- jQuery操作input值的各种方法总结
- 控制input的CSS但不影响CheckBox以及Radio的样式
- 揭秘SQL Server 2014有哪些新特性(2)-固态硬盘 Buffer Pool(缓冲池) 扩展
- php中ob(Output Buffer 输出缓冲)函数使用方法
- PHP 命令行工具 shell_exec, exec, passthru, system详细使用介绍
- php中mysql操作buffer用法详解
- js禁用和激活input表单的方法
- 让input不可点击的另一种方法
- input 高级限制级用法
- css美化input file按钮的代码方法
- js正则表达exec与match的区别说明
- js实现input密码框提示信息的方法(附html5实现方法)
- javascript 控制input只允许输入的各种指定内容
- 复制Input内容的js代码_支持所有浏览器,修正了Firefox3.5以上的问题