繁体   English   中英

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

[英]How to create datatable in C#?

我尝试创建并填充一个简单的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;
   }

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

尝试这个:

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;
}
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;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM