我正在尝试编写一些扩展程序,以便将UniDataSets
和UniRecords
转换为DataSet
和DataRow
,但在尝试编译时出现以下错误。< / 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;
}
}
}
}
答案 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();
希望这会有所帮助...