C# - 在数组中存储数据表值
本文关键字:存储 数据表 数组 | 更新日期: 2023-09-27 18:30:46
我想将选择查询的结果存储在 C# 的数组中。请告诉我如何获取数据表值并存储在数组中。我的选择查询结果包含 n 行且仅包含一列。
将type
替换为单列的数据类型(例如 int
, string
, ...并使用单列的名称myField
。
var myArray = (from row in myDataTable.AsEnumerable()
select row.Field<type>("myField")).ToArray();
利用 C# 泛型和类型推断的魔力,您的数组将自动具有正确的数据类型(例如 int[]
, string[]
, ...
尝试这样的事情
private void getData()
{
SqlCeConnection conn = new SqlCeConnection("data source='c:''northwind.sdf'; mode=Exclusive;");
SqlCeDataAdapter da = new SqlCeDataAdapter("Select [Unit Price] from Products", conn);
DataTable dtSource = new DataTable();
da.Fill(dtSource);
DataRow[] dr = new DataRow[dtSource.Rows.Count];
dtSource.Rows.CopyTo(dr, 0);
double[] dblPrice= Array.ConvertAll(dr, new Converter<DataRow , Double>(DataRowToDouble));
}
public static double DataRowToDouble(DataRow dr)
{
return Convert.ToDouble(dr["Unit Price"].ToString());
}
DataTable mydt = new DataTable();
ArrayList aLrows = new ArrayList();
foreach (DataRow dataRow in mydt.Rows)
{
aLrows.Add(string.Join(";", dataRow.ItemArray.Select(item => item.ToString)));
}