質問

Linq to SQLを使用しています。 .SubmitChanges() 'ingに対してDataContextがあります。 IDフィールドの挿入中にエラーが発生しました。このIDフィールドの挿入に使用しているクエリを確認したいと思います。

クエリ自体はクイックウォッチ内に表示されません。デバッガ内のどこで見つけることができますか?

役に立ちましたか?

解決

実際にはあなたの質問に対する非常に簡単な答えがあります

ウォッチウィンドウに貼り付けてください

((System.Data.Objects.ObjectQuery)myLinqQueryVar).ToTraceString()

他のヒント

多くの人が独自の" DebugWriter"を書いています。次のように添付します:

// Add this class somewhere in your project...
class DebugTextWriter : System.IO.TextWriter {
   public override void Write(char[] buffer, int index, int count) {
       System.Diagnostics.Debug.Write(new String(buffer, index, count));
   }

   public override void Write(string value) {
       System.Diagnostics.Debug.Write(value);
   }

   public override Encoding Encoding {
       get { return System.Text.Encoding.Default; }
   }
}

// Then attach it to the Log property of your DataContext...
myDataContext.Log = new DebugTextWriter()

これにより、Linq-to-Sqlが実行しているすべてがVisual Studioのデバッグウィンドウに出力されます。

ポートマンの回答、コンソールアプリケーションの場合は次のように簡単です:

myDataContext.Log = Console.Out;

または、Linq2SQL Profilerのようなものを使用できます。これは、かなり優れたツールであり、実際にはジョブに適したツールです。

  

Linq to SQL Profiler-LinqのリアルタイムビジュアルデバッガーSQLへ

SQLプロファイラーがある場合は実行します。 SQLコマンドテキストを含む、データベースへのすべてのトラフィックが表示されます。

FooDataContext dc = new FooDataContext();

StringBuilder sb = new StringBuilder();
dc.Log = new StringWriter(sb);

var result=from r in dc.Tables select d;

.....
string query=sb.ToString();

Linq to SQL Profilerがこの仕事に適したツールであることに同意します。ただし、お金を使いたくない場合や、単純なことをする必要がある場合は、DebugTextWriterのアプローチが好きです。

この質問を読んだ後、私はもっと堅牢なものを探しに出かけました。また、ダミアンガードメモリ、デバッグ、ファイル、複数の宛先への出力、または単純なデリゲートの使用など、さまざまなことを処理するさまざまなライターの作成に関する非常に良い記事を書きました

彼のアイデアをいくつか使用して、複数のデリゲートを処理できるActionTextWriterを作成しました。ここで共有すると思いました:

using System;
using System.Collections.Generic;
using System.IO;
using System.Text;

namespace Writers
{
    public class ActionTextWriter : TextWriter
    {
        protected readonly List<Action<string>> Actions = new List<Action<string>>();

        public ActionTextWriter(Action<string> action)
        {
            Actions.Add(action);
        }

        public ActionTextWriter(IEnumerable<Action<string>> actions)
        {
            Actions.AddRange(actions);
        }

        public ActionTextWriter(params Action<string>[] actions)
        {
            Actions.AddRange(actions);
        }

        public override Encoding Encoding
        {
            get { return Encoding.Default; }
        }

        public override void Write(char[] buffer, int index, int count)
        {
            Write(new string(buffer, index, count));
        }

        public override void Write(char value)
        {
            Write(value.ToString());
        }

        public override void Write(string value)
        {
            if (value == null)
            {
                return;
            }

            foreach (var action in Actions)
            {
                action.Invoke(value);
            }
        }
    }
}

好きなだけアクションを追加できます。この例では、Debug.Writeを介してVisual Studioのログファイルとコンソールに書き込みます。

// Create data context
var fooDc = new FooDataContext();

// Create writer for log file.
var sw = new StreamWriter(@"C:\DataContext.log") {AutoFlush = true};

// Create write actions.
Action<string> writeToDebug = s => Debug.Write(s);
Action<string> writeToLog = s => sw.Write(s);

// Wire up log writers.
fooDc.Log = new ActionTextWriter(writeToDebug, writeToLog);

そしてもちろん、よりシンプルなものを作成してカフスから外したい場合は、いつでも extend ActionTextWriter ...汎用的なアプローチを記述して再利用できますか?

using System.Diagnostics;
using System.IO;

namespace Writers
{
    public class TraceTextWriter : ActionTextWriter
    {
        public TraceTextWriter()
        {
            Actions.Add(s => Trace.Write(s));
        }
    }

    public class FileTextWriter : ActionTextWriter
    {
        public FileTextWriter(string path, bool append = false)
        {
            var sw = new StreamWriter(path, append) {AutoFlush = true};
            Actions.Add(sw.Write);
        }
    }
}
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top