当前位置:首页 » 数据仓库 » gridview获取行数据库
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

gridview获取行数据库

发布时间: 2022-12-07 18:41:37

‘壹’ 急急:GridView怎么根据行数,获取该行的数据库ID

直接将ID绑定在LinkButton的CommandArgument属性上,点击按钮的时候获取下就可以了,为什么要那么麻烦显示在页面上呢...

‘贰’ GridView获取行数据

你怎么用这个按钮呢 不用其他的呢
你可以换成这个按钮LinkButton 然后添加RowCommand事件 代码如下
<asp:TemplateField HeaderText="操作">
<ItemTemplate>
<asp:LinkButton ID="lbtnDelete" runat="server" Text="删除" CommandArgument= '<%#Eval("RegisterID") %>' CommandName="Delete" OnClientClick="return confirm('是否删除?');"></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
protected void DataGridView_RowCommand(object sender, GridViewCommandEventArgs e)
{

SqlParameter[] param =
{
new SqlParameter("@p_RegisterID",e.CommandArgument.ToString()),
new SqlParameter("@v_Error",null)
};
AccessHelper.ExecuteStoreProce("Admin_DeleteRegister", param);
GridViewBind();

}

‘叁’ gridview怎么获得该行的数据库id

先进入到模板编辑,对linkbutton的CommandArgument属性进行绑定,绑定到数据的id属性上。

最后在gridview的RowCommand事件中:
e.CommandArgument 就可以去到Id了,注意用的时候转型。

如果有多个linkbutton,或者用了gridview自带的删除、修改等,要给你自己的这个linkbutton添加一个CommandName,在RowCommand事件中,先判断e.CommandName是不是你设置的CommandName。

不知道这么解释能不能明白。

‘肆’ GridView1_RowCommand()中如何获取当前行

在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引

protectedvoidgv_Company_RowCommand(objectsender,GridViewCommandEventArgse){
if(e.CommandName=="QianRu")
{
//取ID的值方法一
GridViewRowdrv=((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent));//此得出的值是表示那行被选中的索引值
infid=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value);//此获取的值为GridView中绑定数据库中的主键值

//取ID的值方法二
GridViewRowdrv=((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent));//此得出的值是表示那行被选中的索引值
//此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
intid=Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);

//取ID的值方法三
//因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
intid=Convert.ToInt32(e.CommandArgument.ToString());
}
}

‘伍’ 如何获取gridview中显示的数据

而GridView中却不是如此,就算数据源有表结构,只要没有行记录,就无法显示标题。 我用了如下几种方法来显示,供大家参考一下: 1.使用最简单的,当返回的数据为null时,没有表结构,那么先获取对应的表结构,可以从数据库中获取,也可以临时组合,如: DataTable dt = new DataTable("column"); dt.Columns.Add(ID, typeof(System.Int32)); dt.Columns.Add(Name, typeof(System.String)); 如果返回的数据源有表结构,只是没有行记录,就不用做上面这步了。 然后使用DataRow dr = dt.NewRow(); dt.Rows.Add(dr); 然后再绑定到GridView,这样就可以显示标题了。 这种方法简单,但是有些问题,如果列表中有其他控件,如Select命令,那么显示出来空行连Select也显示出来了,这样看上去会让用户误认为是有一条记录。当然,可以在RowDataBound中判断一下状态,是否清除掉所有控件。 2.使用EmptyDataText 属性来提示用户没有记录,但是这样无法显示标题。 当绑定到 GridView 控件的数据源不包含任何记录时,该控件中显示空数据行。使用 EmptyDataText 属性指定将在空数据行中显示的文本。 3.使用EmptyDataTemplate属性。里面可以包含控件和html标记。 如果同时设置了 EmptyDataText 和 EmptyDataTemplate 属性,则 EmptyDataTemplate 属性优先。 4.CreateChildControls(IEnumerable, bool) 方法: 此方法是根据数据源和相关的设置来创建需要显示的控件,主要是一个表格,此返回创建的控件数, 如果数据源中没有数据,GridView 将根据 EmptyDataTemplate 和 EmptyDataText 两个属性来显示 信息,如果这两个属性都没有设置,GridView 将不显示任务的内容。 在 DataGrid 中,如果数据源没有数据,将也会显示一个表头,GridView 不显示表头了,对于有些 用户来说,可能有点不习惯。 如果需要在没有数据的时候也要显示表示,可以重写此方法,在此方法,通过 CreateColumns 方法 获取到需要显示的列,在调用 CreateRow 方法创建一行,在调用 IntializeRow 方法来初始化创建 的行,最后在把行添加到表格里,这里需要说明的一点是,如果 GridView 没有显示任何的东西,