如何在C#中创建数据表?

时间:2014-12-10 10:16:20

标签: c# datatable

我尝试创建并填充一个简单的DataTable

此代码的结果:

   Order     Driver
    1
               1

但我想在同一行显示:

  Order     Driver
    1         1

我的错在哪里?

   public DataTable MethodName(string Param)
    {
        DataRow dr;
        DataTable dt= new DataTable();
        dt.Columns.Add("Order", Type.GetType("System.Int32"));
        dt.Columns.Add("Driver", Type.GetType("System.Int32"));

      if(AnotherMethod1(Param))
       {    dr = dt.NewRow();
            dr["Order"] = 1;
            dt.Rows.Add(dr);
       }
      else 
      {     dr = dt.NewRow();
            dr["Order"] = 0;
            dt.Rows.Add(dr);
      }
      if(AnotherMethod2(Param))
      {     dr = dt.NewRow();
            dr["Driver"] = 1;
            dt.Rows.Add(dr);
      }
      else
      {     dr = dt.NewRow();
            dr["Driver"] = 0;
            dt.Rows.Add(dr);
       }
      return dt;
   }

2 个答案:

答案 0 :(得分:3)

每次将值设置为其他列时,都会添加一行。

试试这个:

public DataTable MethodName(string Param)
{
    DataTable dt = new DataTable();
    dt.Columns.Add("Order", typeof(Int32));
    dt.Columns.Add("Driver", typeof(Int32));

    DataRow dr = dt.NewRow();
    dr["Order"] = AnotherMethod1(Param) ? 1 : 0;
    dr["Driver"] = AnotherMethod2(Param) ? 1 : 0;
    dt.Rows.Add(dr);           
    return dt;
}

答案 1 :(得分:2)

public DataTable MethodName(string Param)
{
    DataRow dr;
    DataTable dt= new DataTable();
    dt.Columns.Add("Order", Type.GetType("System.Int32"));
    dt.Columns.Add("Driver", Type.GetType("System.Int32"));

    dr = dt.NewRow();
    if(AnotherMethod1(Param))
    {    
        dr["Order"] = 1;
    }
    else 
    {     
        dr["Order"] = 0;            
    }
    if(AnotherMethod2(Param))
    {     
        dr["Driver"] = 1;
    }
    else
    {     
        dr["Driver"] = 0;            
    }
    dt.Rows.Add(dr);
    return dt;
}