dポイントプレゼントキャンペーン実施中!

SQL Server2008でパフォーマンスの悪いSQLなどを調べようと思い、
以下のような説明を参考にしています。
http://msdn.microsoft.com/ja-jp/magazine/cc13597 …
http://msdn.microsoft.com/ja-jp/library/ms189741 …

しかし、エラーが出て実行できません。
SQL文から抜粋しますと、以下の様なエラーが発生ます。

 ・THEN LEN(CONVERT(nvarchar(max), qt.text)) * 2
   →'max' の近くに無効な構文があります。

 ・CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
   →'APPLY' の近くに無効な構文があります。

 ・SELECT qs.execution_count
  FROM sys.dm_exec_query_stats AS qs
   →'sys.dm_exec_query_stats' は無効です。

調べても何が悪いのかわからず困っています。
何がいけないのかご教授いただけませんでしょうか。
よろしくお願い致します。

A 回答 (1件)

SQL分の効率分析ツールなら、SQL Server Profilerを勧めます。



スタートー>すべてのプログラムー>Microsoft SQL Server 2008ー>パフォーマンスツールー>SQL Server Profiler

新しいトレースを作成して、実行すると、SQL文のパフォーマンスを見ることができます。

ご参考になれればと思います。

この回答への補足

ご回答いただきありがとうございます。

実はSQL Server Profilerをわからないなりに使用してました。
ところがストアドプロシージャの中のSQLのパフォーマンスを
調べたかったのですが、SQL Server Profilerではストアドプロシージャの
名前しか表示されず、その中で実行されているSQLが見えなかったのです。

そのため、先述の方法で調べようとして質問させていただいた次第でした。

なので、もしストアドプロシージャの中のSQLについて調べる方法があれば、
それでも結構ですのでアドバイスいただけると幸いです。

補足日時:2013/12/10 13:12
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!