簡體   English   中英

按鈕單擊后不顯示ASP.NET GridView

[英]ASP.NET GridView Not Appearing After Button Click

我有一個名為ddlSvcEngr的下拉列表從數據源獲取值。 我希望gridview根據ddlSvcEngr的選擇顯示數據庫的結果。 但每次單擊視圖按鈕時都沒有出現gridview。 這是代碼:

HTML:

<asp:DropDownList ID="ddlSvcEngr" runat="server" DataSourceID="SqlDataSource1" DataTextField="rep_svcengr" DataValueField="rep_svcengr" CssClass="btn btn-default dropdown-toggle" Width="300px" AppendDataBoundItems="true">    
<asp:Button ID="btnView" runat="server" Text="View" CssClass="btn btn-primary" Width="300px" OnClick="btnView_Click" />
<asp:GridView ID="gvResults" runat="server" AutoGenerateColumns="False" ShowFooter="True">
            <Columns>
                <asp:BoundField ItemStyle-Width="150px" DataField="rep_svcengr" HeaderText="Service Engineer" >
                    <ItemStyle Width="150px"></ItemStyle>
            </Columns>
</asp:GridView>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:jasonsvcConnectionString %>" SelectCommand="SELECT [rep_svcengr], [rep_company], [rep_vessel], [rep_wo], [rep_brand], [rep_model], [rep_eqpt], [rep_sn] FROM [reports]"></asp:SqlDataSource>

代碼背后:

private void bgSvcEngr()
    {
        string conString = ConfigurationManager.ConnectionStrings["jasonsvcConnectionString"].ConnectionString;
        string query = "SELECT rep_svcengr,rep_company,rep_vessel,rep_wo,rep_brand,rep_model,rep_eqpt,rep_sn FROM reports WHERE rep_svcengr='@svcengr'";
        SqlCommand cmd = new SqlCommand(query);
        cmd.Parameters.AddWithValue("@svcengr", ddlSvcEngr.SelectedItem.Value);
        using (SqlConnection con = new SqlConnection(conString))
        {
            using (SqlDataAdapter sda = new SqlDataAdapter())
            {
                cmd.Connection = con;
                sda.SelectCommand = cmd;
                using (DataSet ds = new DataSet())
                {
                    sda.Fill(ds);
                    gvResults.DataSource = ds;
                    gvResults.DataBind();
                }
            }
        }
    }

protected void btnView_Click(object sender, EventArgs e)
    {            
            bgSvcEngr();
    }

注意:每次我從命令查詢中刪除行WHERE rep_svcengr='" + ddlSvcEngr.SelectedIndex.ToString() + "' 單擊“查看”按鈕后會出現gridview。

我不知道為什么每次將WHERE命令放入查詢時都不會出現gridview的問題。

擺脫單引號:

更換:

WHERE rep_svcengr='@svcengr'

附:

WHERE rep_svcengr=@svcengr

在此輸入圖像描述

public partial class WebForm1 : System.Web.UI.Page
{
    protected void Button1_Click(object sender, EventArgs e)
    {
        SelectByColor();
    }
    private void SelectByColor()
    {
        string conString = ConfigurationManager.ConnectionStrings["AdventureWorks2014ConnectionString"].ConnectionString;
        string query = "SELECT productid, name, color FROM production.product WHERE color=@pcolor";
        SqlCommand cmd = new SqlCommand(query);
        cmd.Parameters.AddWithValue("@pcolor", DropDownList1.SelectedItem.Value);
        using (SqlConnection con = new SqlConnection(conString))
        {
            using (SqlDataAdapter sda = new SqlDataAdapter())
            {
                cmd.Connection = con;
                sda.SelectCommand = cmd;
                using (DataSet ds = new DataSet())
                {
                    sda.Fill(ds);
                    GridView1.DataSource = ds;
                    GridView1.DataBind();
                }
            }
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM