首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Gridview未执行UpdateCommand

Gridview未执行UpdateCommand
EN

Stack Overflow用户
提问于 2011-06-30 02:52:34
回答 2查看 948关注 0票数 0

这非常有趣,因为我在两个不同的项目中使用了相同的代码结构,其中一个工作得很好,但另一个甚至不能执行。

下面是asp.net代码(BulkEditGridview是一个扩展控件,它使用gridview作为基本控件,所以它的工作方式基本上是一样的)

代码语言:javascript
复制
<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();

下面是数据源和按钮代码:

代码语言:javascript
复制
 <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" />

这段代码是不能工作的,但是这段代码工作起来很棒:

代码语言:javascript
复制
   <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,&#13;&#10;'delete_preInvoice.aspx?id='+cast(payment.id as nvarchar(10)) as urlDeleteP&#13;&#10;, 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我可以看到它没有执行updatecommand,并且从Sql server management studio测试了存储过程,它工作得很好。

这也不是一个连接问题,因为selectCommand可以工作,并且它从DB加载信息。

有什么想法吗?

EN

回答 2

Stack Overflow用户

发布于 2011-06-30 03:26:09

不知道它是否相关,这有点奇怪,但您的工作代码中有类型为string的id:

代码语言:javascript
复制
<asp:Parameter Name="id" type=String />    

同时,在不起作用的情况下,你有

代码语言:javascript
复制
<asp:Parameter Name="id" Type=Int32 />

如果你真的在你的BulkEditGridView1.Save();方法中使用了几乎相同的代码,理论上它可能会带来麻烦。

票数 0
EN

Stack Overflow用户

发布于 2011-06-30 03:29:49

我认为这个问题是因为你的按钮上有一个自定义事件。

代码语言:javascript
复制
onclick="Button1_Click"

框架将开始寻找该事件,并认为您将自己处理保存。

但是为什么你在那里有一个保存按钮呢?您可以使用gridview控件中内置的按钮。可以在属性或向导中激活编辑选项。

因为如果你想使用你自己的控件,那么你需要在每一行上添加一个,所以你需要添加一个模板行,并在其中添加按钮。

嗯,我认为什么都没发生是很正常的。我认为,当按钮位于网格视图中时,就会使用您用来将其链接到按钮的网格视图的属性。

现在我知道你在找什么了,我建议你看看这篇教程。它讨论了你试图完成的相同的事情。Link

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6525715

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档