Skip to content

Using ASP.NET Web Forms, Passing Primary Key to RowCommand Event

Updated: at 12:10 AM

 

I know this is old hat, but after recently having a conversation with one of the ASP.NET Team guys about how easy Web Forms is to use, I thought I’d just post a simple example of that.  Here is the scenario.  You have a simple GridView with just three columns (Select,Id,TagName).  You want to be able to capture what happens when the user pressed the Select command and capture the Id.  It looks like this:

 

image

 

And has an aspx page like this:

 

<asp:GridView ID="GridViewNotSelected" runat="server" AllowSorting="True" 
AutoGenerateColumns="False"
DataSourceID="SqlDataSourceTagsNotSelected"
onrowcommand="GridViewNotSelected_RowCommand">
<Columns>
<asp:TemplateField ShowHeader="False">
<ItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server"
CausesValidation="False" CommandArgument='<%# Eval("Id") %>'
CommandName="Select" Text="Select"></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField
HeaderText="&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;">
</asp:TemplateField>
<asp:TemplateField>
<ItemTemplate>
<asp:Label ID="Label1" Text='<%# Eval("TagName") %>' runat="server"></asp:Label>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

Notice that in the TemplateField there is LinkButton with a CommandArgument that simply extracts the TagName with the current Id of the SqlDataSource.  Now, all you need is the RowCommand event and you are done.  Here it is in C#.

 

protected void GridViewNotSelected_RowCommand(object sender, GridViewCommandEventArgs e)
{
int tagsId = Convert.ToInt32(e.CommandArgument);
}

And finally, the proof!

 

image

 

Very very simple.  HTH’s.

Check out the ORM (Object Relational Mapper) PRISMA. The database access method I use in all my projects