AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题 / 5881
Accepted
Ben Brocka
Ben Brocka
Asked: 2011-09-17 12:41:08 +0800 CST2011-09-17 12:41:08 +0800 CST 2011-09-17 12:41:08 +0800 CST

SQL Server 2005 中的最近查询

  • 772

我正在使用 PHP Web 应用程序与数据库交互,需要捕获错误查询。它是动态生成的 SQL,我不知道 100% 的代码,也不是我编写的,所以我需要看看它在做什么。

使用 SQL Server Management Studio 2008,我发现很难找到数据库中最后执行的 n 个查询。我搜索了一场风暴,但我见过的所有解决方案都需要“sql_handle”,这是我数据库兼容级别中不可用的功能,并且启动我见过的所有解决方案似乎都没有捕获动态查询,这网络应用程序使用。

我正在使用这个查询:

SELECT TOP 50 * FROM(SELECT COALESCE(OBJECT_NAME(s2.objectid),'Ad-Hoc') AS ProcName,
  execution_count,s2.objectid,
    (SELECT TOP 1 SUBSTRING(s2.TEXT,statement_start_offset / 2+1 ,
      ( (CASE WHEN statement_end_offset = -1
  THEN (LEN(CONVERT(NVARCHAR(MAX),s2.TEXT)) * 2)
ELSE statement_end_offset END)- statement_start_offset) / 2+1)) AS sql_statement,
       last_execution_time
FROM sys.dm_exec_query_stats AS s1
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2 ) x
WHERE sql_statement NOT like 'SELECT TOP 50 * FROM(SELECT %'
ORDER BY last_execution_time DESC

但它要求在 SQL Server 2005 中更改 sp_dbcmptlevel(搜索要求 comptlevel 为 90,我需要它为 80),这是不可接受的,并且在最近的情况下甚至不返回在数据库上运行的任何动态查询;它只返回存储过程的操作。

具有相同的兼容性和不完整结果问题的类似解决方案是:

SELECT deqs.last_execution_time AS [Time], dest.TEXT AS [Query]
FROM sys.dm_exec_query_stats AS deqs
CROSS APPLY sys.dm_exec_sql_text(deqs.sql_handle) AS dest
ORDER BY deqs.last_execution_time DESC

这个返回一个非常小且非常奇怪的查询子集,包括最近的查询(通常是它本身)和一堆create procedure语句。

SSMS 或系统数据库查询是否有任何功能可以让我查看或捕获最近的查询?如果我必须以某种方式捕获和保存查询字符串,那是可以接受的,因为这仅在测试系统中。

sql-server ssms
  • 2 2 个回答
  • 1276 Views

2 个回答

  • Voted
  1. Best Answer
    Nick Chammas
    2011-09-17T12:55:03+08:002011-09-17T12:55:03+08:00

    SQL Server Profiler 就是为此而设计的。

    有了它,您可以:

    • 捕获在目标实例上执行的查询
    • 捕获其他实例和数据库事件,例如死锁、登录和错误
    • 按查询中的文本、登录名、数据库名称等过滤捕获的查询
    • 3
  2. Wil
    2011-09-17T13:00:00+08:002011-09-17T13:00:00+08:00

    如果您获得运行查询的 SPID,这将为您提供最后运行的语句:

    DECLARE @sqltext VARBINARY(128)
    
    SELECT @sqltext = sql_handle
    FROM sys.sysprocesses
    WHERE spid = 85 --replace this with your SPID
    
    SELECT TEXT
    FROM sys.dm_exec_sql_text(@sqltext)
    
    • 2

相关问题

  • SQL Server - 使用聚集索引时如何存储数据页

  • 我需要为每种类型的查询使用单独的索引,还是一个多列索引可以工作?

  • 什么时候应该使用唯一约束而不是唯一索引?

  • 死锁的主要原因是什么,可以预防吗?

  • 如何确定是否需要或需要索引

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    您如何显示在 Oracle 数据库上执行的 SQL?

    • 2 个回答
  • Marko Smith

    如何选择每组的第一行?

    • 6 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    我可以查看在 SQL Server 数据库上运行的历史查询吗?

    • 6 个回答
  • Marko Smith

    如何在 PostgreSQL 中使用 currval() 来获取最后插入的 id?

    • 10 个回答
  • Marko Smith

    如何在 Mac OS X 上运行 psql?

    • 11 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Marko Smith

    将数组参数传递给存储过程

    • 12 个回答
  • Martin Hope
    Manuel Leduc PostgreSQL 多列唯一约束和 NULL 值 2011-12-28 01:10:21 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Stuart Blackler 什么时候应该将主键声明为非聚集的? 2011-11-11 13:31:59 +0800 CST
  • Martin Hope
    pedrosanta 使用 psql 列出数据库权限 2011-08-04 11:01:21 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST
  • Martin Hope
    BrunoLM Guid vs INT - 哪个更好作为主键? 2011-01-05 23:46:34 +0800 CST
  • Martin Hope
    bernd_k 什么时候应该使用唯一约束而不是唯一索引? 2011-01-05 02:32:27 +0800 CST
  • Martin Hope
    Patrick 如何优化大型数据库的 mysqldump? 2011-01-04 13:13:48 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve