如何将SQL Server分析器跟踪限制到特定的数据库?我不知道如何过滤跟踪以不看到所连接的实例上所有数据库的事件。
当前回答
通过实验,我观察到:
当SQL Profiler 2005或SQL Profiler 2000与SQLServer 2000中的数据库一起使用时,上面提到的问题仍然存在,但是当SQL Profiler 2005与SQLServer 2005数据库一起使用时,它工作得很完美!
总之,这个问题似乎在SQLServer 2000中很普遍,并在SQLServer 2005中得到了纠正。
在处理SQLServer 2000时,这个问题的解决方案是(由wearejimbo解释)
通过查询如下所示的sysdatabases表,确定要筛选的数据库的DatabaseID SELECT * 从主. . sysdatabases WHERE name like '%your_db_name%'——删除这一行以查看所有数据库 dbid订购 在SQL Profiler 2000的新建跟踪窗口中使用DatabaseID筛选器(而不是DatabaseName)
其他回答
在跟踪属性>事件选择选项卡>选择显示所有列。现在,在列筛选器下,您应该看到数据库名称。为Like部分输入数据库名称,您应该只看到该数据库的跟踪。
在SQL 2005中,首先需要在跟踪中显示Database Name列。最简单的方法是选择Tuning模板,该模板已经添加了该列。
假设你选择了Tuning模板,要进行筛选:
点击“事件选择”页签 点击“列筛选器”按钮 检查显示所有列(右侧向下) 选择“DatabaseName”,单击右边窗格中Like旁边的加号,并键入您的数据库名称。
我总是将跟踪保存到一个表中,这样我就可以在事后对跟踪数据进行LIKE查询。
在Trace属性中选择Event Selection选项卡。然后单击Show All Columns单选按钮。之后,单击Column Filters按钮。
现在可以看到Database Name属性并单击它。展开like框并插入您的DB名称,然后单击ok,现在就可以运行分析器了。
通过实验,我观察到:
当SQL Profiler 2005或SQL Profiler 2000与SQLServer 2000中的数据库一起使用时,上面提到的问题仍然存在,但是当SQL Profiler 2005与SQLServer 2005数据库一起使用时,它工作得很完美!
总之,这个问题似乎在SQLServer 2000中很普遍,并在SQLServer 2005中得到了纠正。
在处理SQLServer 2000时,这个问题的解决方案是(由wearejimbo解释)
通过查询如下所示的sysdatabases表,确定要筛选的数据库的DatabaseID SELECT * 从主. . sysdatabases WHERE name like '%your_db_name%'——删除这一行以查看所有数据库 dbid订购 在SQL Profiler 2000的新建跟踪窗口中使用DatabaseID筛选器(而不是DatabaseName)
在Trace属性中,单击顶部General旁边的Events Selection选项卡。然后点击列过滤器…在右下角。然后可以选择要过滤的内容,比如TextData或DatabaseName。
展开Like节点并输入您的筛选器,使用百分比%符号,如%MyDatabaseName%或%TextDataToFilter%。如果没有%%符号,过滤器将无法工作。
此外,确保选中复选框排除不包含值的行'如果你找不到你想要过滤的字段,如DatabaseName,去General选项卡并更改你的模板,空白的应该包含所有字段。
推荐文章
- 确定记录是否存在的最快方法
- 从现有模式生成表关系图(SQL Server)
- 我如何循环通过一组记录在SQL Server?
- 数据库和模式的区别
- 如何在SQL Server中一次更改多个列
- 外键约束可能导致循环或多条级联路径?
- 如何选择每一行的列值不是独特的
- nvarchar(max)非文本
- 在SQL Server 2008 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- 修改列,添加默认约束
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?