0

通过此代码,我收到错误“输入数组长于此表中的列数”

DataTable dtMain = new DataTable();
var qry = from c in db.Categories where c.SubCategoryName.Contains(txtSearch.Text.Trim()) select c;
foreach (var k in qry)
{
      var qry1 = from c in db.ProductMasters where c.ProductNameID == k.CategoryID
                  select new { ProductID = c.ProductID, 
                               TagID = c.TagID, 
                               ProductNameID = (from d in db.Categories 
                                                where d.CategoryID == c.ProductNameID 
                                                select d.SubCategoryName).FirstOrDefault(),
                               CategoryID = (from d in db.Categories 
                                                 where d.CategoryID == c.CategoryID 
                                                 select d.CategoryName).FirstOrDefault(), 
                               ProductType = c.ProductType, 
                               Maker = c.Maker, 
                               Model = c.Model, 
                               SerialNo = c.SerialNo, 
                               MACAddress = c.MACAddress, 
                               Warranty = c.Warranty, 
                               Price = c.Price, 
                               ProductOrderNo = c.ProductOrderNo, 
                               VendorID = (from d in db.Vendors 
                                           where d.VendorID == c.VendorID 
                                           select d.VendorName).FirstOrDefault(), 
                               PurchaseDate = c.PurchaseDate.ToString().Substring(0, 10), 
                               ProductStatus = c.ProductStatus, 
                               Remark = c.Remark };
     dtMain.Rows.Add(qry1);

 }

gridProduct.DataSource = dtMain;
gridProduct.DataBind();
4

1 回答 1

0

数据表适用于行和列的概念。您需要先提及所有列名。像这样向数据表添加行。

DataTable dtMain = new DataTable();


for (int i = 0; i < rows .Count(); i++)
            {

                DataRow datarowObj= dtMain .NewRow();
                datarowObj["A"] = yourValue;
                datarowObj["B"] = yourValue;
                datarowObj["C"] = yourValue;
                dtMain .Rows.Add(datarowObj);
            }

或者,正如 SLAKS 提到的关于 bindingList 的那样。您可以使用。绑定列表

return new BindingList<YourClass>(qry1.ToList())
于 2013-02-27T04:50:44.917 回答