如何处理从 DataContext.ExecuteQuery 返回的未知类型的对象

How to work with objects of unknown type returned from DataContext.ExecuteQuery(如何处理从 DataContext.ExecuteQuery 返回的未知类型的对象)
本文介绍了如何处理从 DataContext.ExecuteQuery 返回的未知类型的对象的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

因此,随着 C# 4.0 中 dynamic 关键字的出现,我希望能够找到更好的解决方案来解决选择任意列时由 DataContext.ExecuteQuery 返回的类型的问题.

So, with the advent of the dynamic keyword in C# 4.0 I am hoping I can find a better solution to the problem of dealing with types returned by DataContext.ExecuteQuery when arbitrary columns are selected.

过去我要么创建了一个新类型来保存此类查询的结果,要么使用了描述的方法 在此 SO 帖子中.因此,现在我能够处理在 .NET 4.0 下运行的新项目,我考虑使用动态类型以更轻松的方式完成相同的事情.

In the past I have either created a new type to hold the result of such a query or used the method described in this SO post. So, now that I am able to work on a new project running under .NET 4.0, I looked into using a dynamic type to accomplish the same thing in a less painful manner.

所以,我试了一下:

var result = _db.ExecuteQuery<dynamic>( "SELECT CustomerID,City FROM Customers", new object[0] );
foreach( var d in result )
{
    MessageBox.Show( String.Format( "{0}, {1}", d.CustomerID, d.City ) );        
}

运行时抛出异常,因为动态对象的 CustomerID 属性不存在.因此,由于到目前为止我对 dynamic 关键字的经验为零(一两篇文章/博文,没有真正的经验),我希望这里有人可以让我知道我在这里尝试做的事情是否可行.我可能高估了 ExecuteQuery 背后的魔法"数量,但我认为由于在幕后完成的属性映射,这可能会起作用.非常感谢任何帮助.

An exception is thrown at runtime because the property CustomerID does not exist for the dynamic object. So, since my experience with the dynamic keyword to this point is nil (an article/blog post or two, no real experience) I was hoping someone here could let me know if what I am trying to do here is even possible. I am probably overestimating the amount of 'magic' behind ExecuteQuery, but I thought this may work due to the property mapping done behind the scenes. Any help is much appreciated.

推荐答案

最近,我们编写了 dapper,非常适合原始问题:

More recently, we've written dapper, which fits the original question beautifully:

var result = connection.Query( "SELECT CustomerID,City FROM Customers");
foreach( var d in result )
{
    MessageBox.Show( String.Format( "{0}, {1}", d.CustomerID, d.City ) );        
}

它允许参数等,并且有一个通过 Query 的(首选)类型化 API - 但 dynamic API 也能正常工作.

It allows parameters etc, and there is a (preferred) typed API via Query<T> - but the dynamic API works fine too.

这篇关于如何处理从 DataContext.ExecuteQuery 返回的未知类型的对象的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Is Unpivot (Not Pivot) functionality available in Linq to SQL? How?(Linq to SQL 中是否提供 Unpivot(非 Pivot)功能?如何?)
How to know if a field is numeric in Linq To SQL(如何在 Linq To SQL 中知道字段是否为数字)
Linq2SQl eager load with multiple DataLoadOptions(具有多个 DataLoadOptions 的 Linq2SQl 急切加载)
Extract sql query from LINQ expressions(从 LINQ 表达式中提取 sql 查询)
LINQ Where in collection clause(LINQ Where in collection 子句)
Orderby() not ordering numbers correctly c#(Orderby() 没有正确排序数字 c#)