这很有趣,因为我在2个不同的项目中使用相同的代码结构,其中1个工作正常但另一个工作甚至都没有执行。
这是asp.net代码(BulkEditGridview是一个扩展控件,它使用gridview作为基本控件,所以它基本上以相同的方式工作)
<cc1:BulkEditGridView ID="BulkEditGridView1" runat="server" DataKeyNames="id"
AutoGenerateColumns="False" BackColor="White" BorderColor="#CCCCCC"
BorderStyle="None" BorderWidth="1px" CellPadding="3"
DataSourceID="titlesSqlDataSource" EnableInsert="False"
EnableModelValidation="True" SaveButtonID="Button1">
<Columns>
<asp:BoundField DataField="title" HeaderText="Title" SortExpression="title" />
<asp:BoundField DataField="siteid" HeaderText="SiteID" ReadOnly="True"
SortExpression="siteid" />
<asp:BoundField DataField="block" HeaderText="Block" SortExpression="block" >
<ControlStyle Width="50px" />
<HeaderStyle Width="50px" />
<ItemStyle Width="50px" />
</asp:BoundField>
</Columns>
<FooterStyle BackColor="White" ForeColor="#000066" />
<HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="White" ForeColor="#000066" HorizontalAlign="Left" />
<RowStyle ForeColor="#000066" />
<SelectedRowStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
Button1回发甚至执行BulkEditGridView1.Save();
这是数据源和按钮代码:
<asp:SqlDataSource ID="titlesSqlDataSource" runat="server"
ConnectionString="<%$ ConnectionStrings:xxxx %>"
SelectCommand="sp_getBottomLinksTitles" SelectCommandType="StoredProcedure"
UpdateCommand="sp_updateBlockTitle" UpdateCommandType="StoredProcedure">
<SelectParameters>
<asp:SessionParameter DefaultValue="1" Name="siteid" SessionField="siteid"
Type="Int32" />
</SelectParameters>
<UpdateParameters>
<asp:Parameter Name="title" Type=String />
<asp:Parameter Name="id" Type=Int32 />
<asp:Parameter Name="block" Type=Int32 />
</UpdateParameters>
</asp:SqlDataSource>
<asp:Button ID="Button1" runat="server" Text="Save" onclick="Button1_Click" />
那个代码不起作用,但这个代码就像一个魅力:
<cc1:BulkEditGridView ID="GridViewExistingInvoices" SaveButtonID="AcceptButton" DataKeyNames=id runat="server" DataSourceID="InvoicesSqlDatasource" Font-Bold="False" AutoGenerateColumns="False" BackColor="White" BorderColor="#999999" BorderStyle="Solid" BorderWidth="1px" CellPadding="3" ForeColor="Black" GridLines="Vertical" Width="915px" AllowSorting="True">
<FooterStyle BackColor="#CCCCCC" />
<EmptyDataTemplate> No Invoices to make</EmptyDataTemplate>
<Columns>
<asp:BoundField DataField="date" ItemStyle-Font-Size="11px" HeaderText="Invoice Date" SortExpression="date" DataFormatString="{0:dd-MMM-yyyy}" ItemStyle-VerticalAlign="Top">
<HeaderStyle Width="80px" />
<ItemStyle Width="80px" Font-Size="11px"/>
<ControlStyle Width="80px" Font-Size="11px" />
</asp:BoundField>
<asp:TemplateField HeaderText="Amount">
<ItemTemplate>
<asp:TextBox Text='<%# Bind("Amount1") %>' Font-Size="11px" Width="60px" runat=server ID="amount">
</asp:TextBox><br/>
<asp:TextBox Text='<%# Bind("Amount2") %>' Font-Size="11px" Width="60px" runat=server ID="TextBox1">
</asp:TextBox><br/>
<asp:TextBox Text='<%# Bind("Amount3") %>' Font-Size="11px" Width="60px" runat=server ID="TextBox2">
</asp:TextBox><br/>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Payment Due">
<ItemTemplate>
<asp:TextBox Text='<%# Bind("payment_Due") %>' Font-Size="11px" Width="70px" runat=server ID="tdue1">
</asp:TextBox><br/>
<asp:TextBox Text='<%# Bind("due2") %>' Font-Size="11px" Width="70px" runat=server ID="tdue2">
</asp:TextBox><br/>
<asp:TextBox Text='<%# Bind("due3") %>' Font-Size="11px" Width="70px" runat=server ID="tdue3">
</asp:TextBox><br/>
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="Amount" ItemStyle-Font-Size="11px" HeaderText="Total Amount" SortExpression="Amount" DataFormatString="{0:c}" ItemStyle-VerticalAlign="Top" >
<HeaderStyle Width="60px" />
<ItemStyle Width="60px" Font-Size="11px"/>
<ControlStyle Width="60px" Font-Size="11px" />
</asp:BoundField>
<asp:BoundField DataField="T" HeaderText="T" ItemStyle-Font-Size="11px" SortExpression="T" ItemStyle-VerticalAlign="Top">
<HeaderStyle Width="25px" />
<ItemStyle Width="25px" Font-Size="11px"/>
<ControlStyle Width="40px" Font-Size="11px"/>
</asp:BoundField>
<asp:TemplateField HeaderText="Invoice Description">
<ItemTemplate>
<asp:TextBox Text='<%# Bind("Description") %>' Font-Size="11px" Width="200px" TextMode=MultiLine Height=50px runat=server ID="tDescription">
</asp:TextBox>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Comments">
<ItemTemplate>
<asp:TextBox Text='<%# Bind("Comments") %>' Font-Size="11px" Width="190px" TextMode=MultiLine Height=50px runat=server ID="tComments">
</asp:TextBox>
</ItemTemplate>
</asp:TemplateField>
<asp:CheckBoxField DataField="isblack" ItemStyle-Font-Size="11px" HeaderText="B" SortExpression="isblack" >
<HeaderStyle Width="20px" />
</asp:CheckBoxField>
<asp:CheckBoxField DataField="plusiva" ItemStyle-Font-Size="11px" HeaderText="+IVA" SortExpression="plusiva" >
<HeaderStyle Width="20px" />
</asp:CheckBoxField>
<asp:HyperLinkField DataNavigateUrlFields="url" ItemStyle-Font-Size="11px" HeaderText="Print" Text="Print" >
<HeaderStyle HorizontalAlign="Left" Width="50px" />
</asp:HyperLinkField>
<asp:HyperLinkField DataNavigateUrlFields="urlDeleteP" ItemStyle-Font-Size="11px" Text="Delete" />
</Columns>
<PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
<SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
<HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
<AlternatingRowStyle BackColor="#CCCCCC" />
</cc1:BulkEditGridView>
<asp:SqlDataSource ID="InvoicesSqlDatasource" runat="server" ConnectionString="<%$ ConnectionStrings:xxxConnectionString %>"
SelectCommand="SELECT payment.id,'Not assigned' id1,plusiva,payment.id, payment.[date],CAST( [totalAmount] as decimal(10,2)) as amount,amount as amount1,amount2,amount3,due2,due3, [payment_due], payment.[comments],paymentform AS T , [isblack],'view_invoice.aspx?id='+cast(payment.id as nvarchar(10)) as url, 'delete_preInvoice.aspx?id='+cast(payment.id as nvarchar(10)) as urlDeleteP , Description FROM [payment],lead WHERE (payment.clientid = @id AND payment.clientid=lead.id AND invoiceId is null) ORDER BY [date]"
UpdateCommand="sp_updateInvoiceN" UpdateCommandType=StoredProcedure>
<SelectParameters>
<asp:QueryStringParameter DefaultValue="1" Name="id" QueryStringField="id" Type="Int32" />
</SelectParameters>
<UpdateParameters>
<asp:Parameter Name="date" Type=DateTime/>
<asp:Parameter Name="payment_due" Type=DateTime/>
<asp:Parameter Name="comments" type=String />
<asp:Parameter Name="Description" type=String />
<asp:Parameter Name="amount" type=Double />
<asp:Parameter Name="id" type=String />
<asp:Parameter Name="isBlack" type=Boolean />
<asp:Parameter Name="plusiva" type=Boolean />
<asp:Parameter Name="due2" Type=DateTime/>
<asp:Parameter Name="due3" Type=DateTime/>
<asp:Parameter Name="amount2" type=Double />
<asp:Parameter Name="amount3" type=Double />
<asp:Parameter Name="amount1" type=Double />
</UpdateParameters>
</asp:SqlDataSource>
结构是一样的,使用相同的控件,相同的更新方式,两者都有Datakeynames,两者都在按钮点击事件上执行相同的事情,这有点奇怪,使用sql server profiler我可以看到它doenst执行update命令,并从Sql server management studio测试存储过程,它工作正常。
这不是一个连接问题,因为selectCommand有效,并且它从数据库加载信息。
任何想法??
答案 0 :(得分:0)
不知道它是否相关,它有点奇怪,但你的工作代码id是字符串类型:
<asp:Parameter Name="id" type=String />
同时在你没有工作的那个
<asp:Parameter Name="id" Type=Int32 />
如果你真的在BulkEditGridView1.Save()中使用相同的代码;方法,它理论上可能会引起麻烦。
答案 1 :(得分:0)
我认为问题的原因是您的按钮上有自定义事件。
onclick="Button1_Click"
框架将开始寻找该事件,并认为您将自己处理保存。
但为什么你那边有一个保存按钮?您可以使用gridview控件中内置的按钮。您可以在属性或向导中激活编辑选项。
因为如果你想使用你自己的控件,那么每行需要一个,所以你需要添加一个templaterow并在那里添加按钮。
我认为没有任何事情发生是正常的。当我认为按钮位于gridview内时,会使用gridview将其链接到按钮的属性。
既然我知道你在寻找什么我会建议你看看这个教程。 它讨论了你试图完成的同样的事情。 Link!