我需要使用 ASP.NET 4.5 将当前登录的用户 ID 插入到 Oracle 数据库表中。我在本地 AD 服务器上使用 Windows 身份验证。
当管理员用户单击 Override 按钮时,他们的 ID 需要插入到另一个表中(连同其他两个值),以便我们知道执行覆盖的人是谁。OnClick()
那么这是否意味着我需要在运行 SqlDataSource 的插入命令的 Override 按钮上使用某种方法?或者我将不得不完全以编程方式执行此操作(而不是使用 SqlDataSource 插入命令)?
这是我到目前为止的 GridView:
<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True" AutoGenerateColumns="False"
CellPadding="6" DataSourceID="SqlDataSource" ForeColor="#333333" GridLines="None" PageSize="20"
DataKeyNames="PP_TRANS_REF_NUM" >
<AlternatingRowStyle BackColor="White" />
<Columns>
<asp:TemplateField ShowHeader="false" >
<ItemTemplate>
<asp:Button ID="btnOverride" runat="server" Text="Override" CssClass="pure-button pure-button-active" />
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="PP_TIMESTAMP" HeaderText="Timestamp" SortExpression="PP_TIMESTAMP" ReadOnly="True" />
<asp:BoundField DataField="PP_CARD_CODE" HeaderText="Card Code" SortExpression="PP_CARD_CODE" ReadOnly="True" />
... (Extra Gridview columns, shortened for brevity.
</asp:GridView>
这是我的 SqlDataSource:
<asp:SqlDataSource ID="SqlDataSource" runat="server" ConnectionString="<%$ ConnectionStrings:CxString %>" ProviderName="<%$ ConnectionStrings:CxStringProviderName %>"
SelectCommand="SELECT * FROM Z_PCARD_PRELOAD"
InsertCommand="INSERT INTO Z_PCARD_OVERRIDE (PO_TIMESTAMP, PO_TRANS_REF_NUM, PO_AUTH_USERID) VALUES (:PP_TIMESTAMP, :PP_TRANS_REF_NUM, )"
FilterExpression="PP_MSG_CODE LIKE '%Z%'" >
<InsertParameters>
<asp:ControlParameter ControlID="GridView1" Name="PP_TIMESTAMP" PropertyName="SelectedValue" Type="String" />
<asp:ControlParameter ControlID="GridView1" Name="PP_TRANS_REF_NUM" PropertyName="SelectedValue" Type="String" />
</InsertParameters>
</asp:SqlDataSource>