当前位置:  开发笔记 > 后端 > 正文

如何处理System.Data.DataTableExtensions.CopyToDataTable()中的缺陷

如何解决《如何处理System.Data.DataTableExtensions.CopyToDataTable()中的缺陷》经验,为你挑选了1个好方法。

嘿伙计们,所以我遇到了一些可能是Extension方法.CopyToDataTable中的缺陷.

导入(在VB.NET中)System.Data.DataTableExtensions然后针对IEnumerable调用该方法使用此方法.如果要使用LINQ过滤数据表,然后在最后还原DataTable,则可以执行此操作.

即:

Imports System.Data.DataRowExtensions
    Imports System.Data.DataTableExtensions

    Public Class SomeClass
            Private Shared Function GetData() As DataTable
                Dim Data As DataTable

                Data = LegacyADO.NETDBCall


                Data = Data.AsEnumerable.Where(Function(dr) dr.Field(Of Integer)("SomeField") = 5).CopyToDataTable()


                Return Data

            End Function
    End Class

在上面的示例中,"WHERE"过滤可能不会返回任何结果.如果发生这种情况,CopyToDataTable会抛出异常,因为没有DataRows.

为什么?

正确的行为应该是返回一个Rows.Count = 0的DataTable.

任何人都可以想到一个干净的解决方法,以这种方式调用CopyToDataTable谁不必知道这个问题?

System.Data.DataTableExtensions是一个静态类,所以我无法覆盖行为....任何想法?我错过了什么吗?

干杯

更新:

我已将此问题提交给Connect.我仍然想要一些建议,但如果您同意我的意见,可以通过上面的链接在Connect上投票

干杯



1> 小智..:
someDataTable.AsEnumerable().Where(r => r.Field("SomeField") == "SomeValue").AsDataView().ToTable();

.AsDataView().ToTable()返回一个空表,其结构与someDataTable现在返回的行相同.Where()

推荐阅读
牛尾巴2010
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有