在编写DataSet扩展时,DataRow构造函数不可访问?

时间:2013-04-22 19:54:33

标签: c# extension-methods system.data

我正在尝试编写一些扩展程序,以便将UniDataSetsUniRecords转换为DataSetDataRow,但在尝试编译时出现以下错误。< / p>

  

'System.Data.DataRow.DataRow(System.Data.DataRowBuilder)'由于其保护级别而无法访问

有没有办法解决这个问题,还是应该放弃这种方法,并采取不同的方式?

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Data;
    using IBMU2.UODOTNET;

    namespace Extentions
    {
        public static class UniDataExtentions
        {
            public static System.Data.DataSet ImportUniDataSet(this System.Data.DataSet dataSet, IBMU2.UODOTNET.UniDataSet uniDataSet)
            {
                foreach (UniRecord uniRecord in uniDataSet)
                {
                    DataRow dataRow = new DataRow();
                    dataRow.ImportUniRecord(uniRecord);
                    dataSet.Tables[0].ImportRow(dataRow);
                }

                return dataSet;
            }

            public static void ImportUniRecord(this System.Data.DataRow dataRow, IBMU2.UODOTNET.UniRecord uniRecord)
            {
                int fieldCount = uniRecord.Record.Dcount();

                // ADD COLUMS
                dataRow.Table.Columns.AddRange(new DataColumn[fieldCount]);

                // ADD ROW
                for (int x = 1; x < fieldCount; x++)
                {
                    string stringValue = uniRecord.Record.Extract(x).StringValue;
                    dataRow[x] = stringValue;
                }
            }
        }
    }

2 个答案:

答案 0 :(得分:18)

无论是扩展方法还是任何方法都无关紧要。 DataRow构造函数不可公开访问。您需要使用DataTable.NewRow()方法创建新的DataRow

它将使用数据表中的架构信息来创建与其匹配的行。如果你只是试图在它自己的构造函数上使用,那么对象就不知道应该使用什么模式。

答案 1 :(得分:0)

我尝试了一种更简单的方法,但它适用于多行,也可以应用于单行:

//Declare a variable for multiple rows 
DataRow[] rows = null;

//get some data in a DataTable named table

//Select specific data from DataTable named table
rows = table.Select("column = 'ColumnValue'");

//Read the value in a variable from the row
string ColumnValue = rows[0]["column"].ToString();

希望这会有所帮助...