GridView 遍历每一行,两种写法

方法一:

 
for (i = 0; i < GridViewID.Rows.Count; i++)
{
   CheckBox chkVote =  (CheckBox)GridView1.Rows[i].FindControl("CheckBox2");
}

例如:

 
int intCount = this.GridViewID.Rows.Count; //总行数
int rowsEffected = 0; 
for (int i = 0; i < intCount; i++)
{   //在GridView中添加TextBox模版列并取输入的值
    TextBox tbMark = this.GridViewID.Rows[i].Cells[2].FindControl("TextBox") as TextBox;
    CheckBox CheckSingle = this.GridViewID.Rows[i].Cells[3].FindControl("CheckSingle") as CheckBox;
    if (CheckSingle.Checked)
    {
            paper entity = new paper();
            paper paper_op = new paper_op();
            entity.question_id = long.Parse(this.GridViewID.DataKeys[i].Value.ToString());
            entity.paper_id = long.Parse(Request.QueryString["paperid"].ToString().Trim());
        try
        {
             // entity.point = Convert.ToInt32(tbMark.Text);
            string point = tbMark.Text.ToString();
            if (point == "")
                {
                    Tools.MSBox("不能为空", String.Format("目标.aspx?id={0}", Request.QueryString["id"]));
                }
                else
                {
                    entity.point = Convert.ToInt32(point);
                }
        }
        catch (Exception)
        {
            Tools.MSBox("请输入正确的分数值");
        }
        int result =paper_add(entity);
        if (wwdresult == 1)
        {
            rowsEffected++; //循环
        }
}
if (rowsEffected > 0)
{
    Tools.MSBox("插入成功", String.Format("目标.aspx?id={0}", Request.QueryString["id"]));
}
else
{
    Tools.MSBox("没有选择!", String.Format("目标.aspx?id={0}", Request.QueryString["id"]));
}

方法二:
 
foreach (GridViewRow row in GridViewID.Rows)
{
    CheckBox chkVote = (CheckBox)row.FindControl("chkVote");
}
两种方法没有太大差别,但是如果你不知道GridViewRow这个类型就很难想到使用这种方法。类似的DataList。 

 
foreach (DataListItem dlItem in this.DataListID.Items)
{
    CheckBox chkVote = (CheckBox)dlItem.FindControl("chkVote");
}


 

      在GridView中有一列允许编辑,等它处于编辑状态时是一个TextBox。怎么得到这个TextBox呢?一般我们得到GridView中的控件的方法是在RowDataBound事件中写这行代码((TextBox)e.Row.Cells[8].FindControl("txtFZRQ"));如果用这个方法得到编辑状态下的TextBox时还会出现这个错误:未将对象引用设置到对象的实例。利用下面的方法就可以了。

if ((e.Row.RowState & DataControlRowState.Edit) == DataControlRowState.Edit)
{
     ((TextBox)e.Row.Cells[8].FindControl("txtFZRQ"));
}
 

 

在使用DevExpress控件的Gridview进行数据添加时,可以按照以下步骤进行操作: 1. 首先,需要确保已经连接到数据库,并创建好与Gridview所对应的数据表。 2. 接下来,需要使用GridView的DataRows属性来遍历所有行。可以使用循环来逐行遍历,然后获取每行的数据。 3. 对于每一行数据,需要创建一个与数据表对应的Insert SQL命令,将数据插入到数据库中。 4. 在循环中,逐行执行Insert SQL命令,将数据插入到数据库中。 下面是一个简单的示例代码,用于说明如何使用DevExpress的Gridview将行数据添加到数据库中: using DevExpress.XtraGrid.Views.Grid; using System.Data.SqlClient; private void AddRowsToDatabase() { // 连接到数据库 string connectionString = "YourConnectionString"; SqlConnection connection = new SqlConnection(connectionString); connection.Open(); // 获取GridView的DataRows属性 GridView gridView = gridView1; // 这里假设Gridview的名称为gridView1 for (int i = 0; i < gridView.DataRowCount; i++) { // 获取每一行的数据 object[] rowValues = ((DataRowView)gridView.GetRow(i)).Row.ItemArray; // 创建Insert SQL命令 SqlCommand command = new SqlCommand("INSERT INTO TableName (Column1, Column2, Column3) VALUES (@Value1, @Value2, @Value3)", connection); command.Parameters.AddWithValue("@Value1", rowValues[0]); command.Parameters.AddWithValue("@Value2", rowValues[1]); command.Parameters.AddWithValue("@Value3", rowValues[2]); // 执行Insert SQL命令 command.ExecuteNonQuery(); } // 关闭数据库连接 connection.Close(); } 请注意,以上代码仅为示例,需要根据实际情况进行调整。确保连接字符串正确,以及数据表的列名和参数名称等都正确对应。 希望以上回答能够帮助到您,如有更多疑问,请随时追问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值