How to debug a Linq Lambda Expression?

2019-03-08 20:07发布

I am using Entity Framework and Linq to Entitites.

I would like to know if there is any way in Visual Studio 2012 to debug this code, step by step. At the moment when placing a break point, the cursor goes over it but does not step inside.

I am more interested to see the value of x.e... not the sql generated for example.

Notes: I'm fine with using other tools or Visual Studio plugins.

          IEnumerable<EventPushNotification> eventToPushCollage = eventsForEvaluation
                    .GroupJoin(eventCustomRepository.FindAllPushedEvents(),
                        e => e.Id,
                        p => p.PushedEventId,
                        (e, p) => new { e, p })
                     .Where(x => x.e.DateTimeStart > currentDateTime &&
                        currentDateTime >= x.e.DateTimeStart.AddMinutes(defaultReminders) &&     //  Data from default reminder for collage event in web.config  
                        x.p.Count() == 0)                                           // Check if the Event has not being already pushed
                     .Select(y => new EventPushNotification
                     {
                         Id = y.e.Id,
                         EventTitle = y.e.EventTitle,
                         DateTimeStart = y.e.DateTimeStart,
                         DateTimeEnd = y.e.DateTimeEnd,
                         Location = y.e.Location,
                         Description = y.e.Description,
                         DeviceToken = y.e.DeviceToken
                     });

8条回答
成全新的幸福
2楼-- · 2019-03-08 20:25

You can add breakpoints on any of your own code.

So put the cursor at 'x.e', and press F9.

查看更多
够拽才男人
3楼-- · 2019-03-08 20:35

You can't debug a Lambda expression if you're using a Linq to Entities provider.

But you can take a look at what SQL it translate into. Also if you are willing to suffer a performance hit - you could load it all into Linq to obejcts - and do a Step by step

查看更多
The star\"
4楼-- · 2019-03-08 20:36

Make sure you read the official MSDN doc on this matter:

Debugging LINQ

and please vote for this suggestion on Visual Studio's User Voice page:

Debug Lambda expressions

Allon Guralnek comments on March 18, 2014 12:37 PM about a way of setting a breakpoint with the keyboard only:

@Anonymous: You can do this today by setting a breakpoint inside the lambda, thereby enabling you to inspect each value that comes in and out of the lambda. As far as I know, you can't set a breakpoint inside a lambda using the mouse, you must use the keyboard. Put the cursor inside the lambda body (e.g. on the first token, or anything after the => and the whitespace that follows) then press F9 (or whatever keyboard shortcut you use to place a breakpoint). Only the inside of the lambda statement will turn red, and the debugger will break there for each item the lambda is evaluated against (so for an array of 100 items, using .Where() will cause the breakpoint to hit 100 times).

Here's it in action in my current Visual Studio 2013:

enter image description here

As you can see it works pretty well and allows us to see the value of a given property being tested. This is for sure an awesome tool/life saver! :)

查看更多
太酷不给撩
5楼-- · 2019-03-08 20:37

I don't know how to this directly in Visual Studio, but you should have a look at LinqPad: http://www.linqpad.net/

查看更多
放荡不羁爱自由
6楼-- · 2019-03-08 20:39

No there is no way to see values of x nor e variables because linq to orm is not executed it is translated/interpreted to generate an sql query.

查看更多
劳资没心,怎么记你
7楼-- · 2019-03-08 20:43

The debug run on function called with lambda expression if you use ToList().

Example

bool aFunction(int x) { return x < 10; }
var l = new List<int>() { 5, 6, 11 }.Where(el => aFunction(el)).ToList();
查看更多
登录 后发表回答