在Linq内捕获异常

时间:2014-05-21 11:53:45

标签: c# linq exception

我的C#代码中存在这个问题。我在Linq代码中得到一个异常,并想知道如何捕获它。 我搜索了SO但找不到任何相关问题。

我将查询简化为:

var test = from values in myTable.AsEnumerable()
select new valueSet
{
    ID = values["ID"].ToString(),
    Number = values["Number"].ToString(),
    Name = this.getName(values["Number"].ToString()),
}

由于我在运行函数 getName 时在查询中出现异常,我希望能够捕获异常以及 Number < / em> 我目前在。像这样:

try 
{           
    var test = from values in myTable.AsEnumerable()
    select new valueSet
    {
        ID = values["ID"].ToString(),
        Number = values["Number"].ToString(),
        Name = this.getName(values["Number"].ToString()),
    }
catch (Exception ex)
{
    //I want to use "Number" here!
    throw ex;
}

我知道我在try中声明了我的测试变量,但我可以为每个&#34; linq-loop&#34;存储当前的数字?有什么建议?

2 个答案:

答案 0 :(得分:1)

要实现这一目标,您必须使用&#34;其他&#34;使用扩展方法和lambdas的LINQ语法:

var test = myTable.AsEnumerable().Select(values =>
{
    try
    {
        return new valueSet
        {
            ID = values["ID"].ToString(),
            Number = values["Number"].ToString(),
            Name = this.getName(values["Number"].ToString()),
        };
    }
    catch(Exception ex)
    {
        throw new ApplicationException("cannot load number" + values["Number"].ToString());
    }
});

答案 1 :(得分:1)

快速测试以显示可行的方法。定义自定义异常类:

public class MyException : Exception
{
    public MyException(TestClass testClass)
    {
        TestClass = testClass;
    }
    public TestClass TestClass { get; set; }
}

为了演示,我使用自定义TestClass,但这将是您的表格:

public class TestClass
{
    public int Id {get; set; }
    public int Number { get; set; }
    public string Name {get; set; }
}

您的getName操作如下:

public static string getName(TestClass testClass)
{
        try
        {
            //functionality goes here
            throw new Exception(); // just for demo purposes, throw an exception here
            return testClass.Name;                
        }
        catch (Exception ex)
        {
            throw new MyException(testClass);
        }
}

演示如何捕获数字的主要方法:

 static void Main(string[] args)
    {
        var list = new List<TestClass>() { new TestClass() { Id = 1, Name= "name", Number= 789} };
        try
        {
            var test = (from values in list
                       select new
                       {
                           Id = values.Id,
                           Name = getName(values),
                       }).ToList();
        }
        catch (MyException ex)
        {
            //I want to use "Number" here!
            var number = ex.TestClass.Number;
            throw ex;
        }  
    }

PS - 不介意静态关键字,此测试是在控制台应用程序中完成的。