在运行时在GridView中逐行添加

时间:2011-04-18 06:49:40

标签: c# .net ado.net

我是C#的新手。我想在运行时在GridView中添加行。我从2或3个表中收集数据。但无论何时我去 用GridView绑定()它,最后插入的行被当前的行覆盖。 GridView仅显示当前行。 是否可以显示另一行?或者是否有任何代码可以这样做。请为我建议代码,以便我可以在我的项目中使用它。谢谢。

答案::首先,您必须声明一个静态数据表。一个布尔变量,其值最初为“true”。 然后执行以下代码--->>> 这是我的代码::

protected void btnAdd_Click(object sender, EventArgs e)
{
    int coursemasterid = Convert.ToInt32(dlAdmissionCourses.SelectedItem.Value);
    int batchmasterid = Convert.ToInt32(dlAssignBatch.SelectedItem.Value);


    string SQL1 = "SELECT coursename,coursefees,batchname FROM  CourseMaster,BatchMaster WHERE CourseMaster.coursemasterid=BatchMaster.coursemasterid and CourseMaster.coursemasterid="+coursemasterid+" and BatchMaster.batchmasterid="+batchmasterid+"";
      DataTable otable = new DataTable();
        otable = DbHelper.ExecuteTable(DbHelper.CONSTRING, CommandType.Text, SQL1, null);
        DataRow dr1 = otable.Rows[0];
        string coursename = dr1["coursename"].ToString();
        int coursefees = Convert.ToInt32(dr1["coursefees"]);
        string batchname = dr1["batchname"].ToString();

if (chkadd == true)
        {
            dtglb = new DataTable();  //here dtglb is a global datatable
            dtglb.Columns.Add("coursename", typeof(string));
            dtglb.Columns.Add("coursefees", typeof(int));
            dtglb.Columns.Add("batchname", typeof(string));

        }
        foreach (DataRow dr in otable.Rows)
        {
            dtglb.NewRow();
            dtglb.Rows.Add(coursename,coursefees,batchname);

        }
        chkadd = false;
        GridView1.DataSource = dtglb;
    GridView1.DataBind();           

}

3 个答案:

答案 0 :(得分:1)

答案 1 :(得分:1)

  //declaring a datatable global in form 
        DataTable dtglb=new DataTable();

        //In click event    
    SqlConnection con = new SqlConnection("Data Source=.\\SQLEXPRESS;Initial Catalog=EMS;User ID=sa;Password=sa123");

    string SQL1 = "SELECT coursename,coursefees,batchname FROM  CourseMaster,BatchMaster WHERE CourseMaster.coursemasterid=BatchMaster.coursemasterid and CourseMaster.coursemasterid="+coursemasterid+" and BatchMaster.batchmasterid="+batchmasterid+"";
    SqlCommand cmd = new SqlCommand(SQL1, con);
    SqlDataAdapter da = new SqlDataAdapter(cmd);
    DataTable ds = new DataTable();
    //DataColumn faculty = new DataColumn();
    da.Fill(ds);
    GridView1.DataSourceID = null;

    //New Code Added Here
    DataRow row = ds.NewRow();
    //your columns
    row["columnOne"] = valueofone;
    row["columnTwo"] = valueoftwo;
    dtglb.Rows.Add(row);
        foreach(DataRow dr in dtglb.Rows)
    {
     ds.Rows.Add(dr);
    }
    //=========
    GridView1.DataSource = ds;
    GridView1.DataBind();     

答案 2 :(得分:0)

向DataGridView本身添加行

DataGridViewRow row = new DataGridViewRow();
dataGridView1.BeginEdit();
//your columns
row.Cells["columnOne"] = valueofone;
row.Cells["columnTwo"] = valueoftwo;
dataGridView1.Rows.Add(row);
dataGridView1.EndEdit();