我在迭代数据表并将每个值分配给datacontract列表中的给定属性时遇到了一些困难。
所以我有以下DataContract:
namespace Shared.DataContracts
{
[Serializable]
[DataContract(Name = "DispatchAddress")]
public class DispatchDetails
{
[DataMember(Name = "ShippingAddressCode")]
public string ShippingAddressCode { get; set; }
[DataMember(Name = "ShippingName")]
public string ShippingName { get; set; }
[DataMember(Name = "Address")]
public Address Address { get; set; }
[DataMember(Name = "ContactName")]
public string ContactName { get; set; }
//etc
}
}
在我的服务中,我想返回一个DispatchDetails列表,但我的问题是为每个属性赋值。
public GetDispatchDetailsResponse GetDispatchDetails(string code, string id)
{
GetDispatchDetailsResponse getDispatchDetailsResponse = new GetDispatchDetailsResponse();
List<DispatchDetails> dispatchDetails = new List<DispatchDetails>();
DataTable dt = _dataRetriever.GetDataTable(string.Format(BusinessSqlConstants. DispatchAddress, code, id));
foreach (var row in dt.Rows)
{
foreach (var col in dt.Columns)
{
//The troublesome line of code.
dispatchDetails.Add("ShippingAddressCode") = Convert.ToString(dt.Columns["ShippingAddressCode"]);
//etc
}
}
}
我已经添加了我最新的狡猾的代码行来说明我正在努力实现的目标。我尝试了几种方法但似乎我现在正在努力通过树木看到树木:)
提前感谢任何建议。
亲切的问候,基督徒
答案 0 :(得分:2)
你想这样做吗?
foreach (DataRow row in dt.Rows)
{
var item = new DispatchDetails();
item.ShippingAddressCode = Convert.ToString(row["ShippingAddressCode"]);
item.ShippingName = Convert.ToString(row["ShippingName"]);
// etc.
dispatchDetails.Add(item);
}