asp.net - 在SQLDatasource中使用存储过程时,Gridview不显示

标签 asp.net stored-procedures gridview sqldatasource

我之前偶然发现过这个问题,我知道这是一个常见问题。一个相关问题是GridView is empty 。但这并不能解决我的问题。

理想情况下,我想要的是当我单击“查找”按钮时根据文本框中的值更新我的 GridView 。它在我的其他页面上确实对我有用。但我这里有一些问题。我没有更改任何默认参数。这是 GridView

<asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
    DataSourceID="SqlDataSource1" AutoGenerateColumns="False" 
    DataKeyNames="ID">
    <Columns>
        <asp:BoundField DataField="ID" HeaderText="ID" InsertVisible="False" 
            ReadOnly="True" SortExpression="ID" />
        <asp:BoundField DataField="companyname" HeaderText="companyname" 
            SortExpression="companyname" />
        <asp:BoundField DataField="contactfirstname" HeaderText="contactfirstname" 
            SortExpression="firstname" />
        <asp:BoundField DataField="contactlastname" HeaderText="contactlastname" 
            SortExpression="lastname" />
        <asp:BoundField DataField="phonenumber" HeaderText="phonenumber" 
            SortExpression="phonenumber" />
        <asp:BoundField DataField="contactid" HeaderText="contactid" 
            SortExpression="contactno" />
    </Columns>
</asp:GridView>

在我的“查找”按钮单击事件中。我正在使用这段代码

protected void btnFind_Click(object sender, EventArgs e)
{
    SqlDataSource1.DataBind(); /* Edit: I don't need this, I realized */
}

但它没有加载任何东西。整个 GridView 不会出现。如果我使用 select 语句, GridView 会显示结果。我已经在 gridview 中测试了我的存储过程,它按应有的方式工作。不知道这里到底可能是什么问题?有人遇到过吗?

我想我在某处读到如果存储过程返回0结果,gridview将不会显示。

我的SQL数据源

<asp:SqlDataSource ID="SqlDataSource1" runat="server" 
    ConnectionString="<%$ ConnectionStrings:MyDBconn %>" 
    SelectCommand="usp_GetContactNo" SelectCommandType="StoredProcedure">
    <SelectParameters>
        <asp:FormParameter DefaultValue="" FormField="txtCompanyName" 
            Name="companyname" Type="String" />
        <asp:FormParameter FormField="txtFirstName" Name="firstname" Type="String" />
        <asp:FormParameter FormField="txtLastName" Name="lastname" Type="String" />
        <asp:FormParameter FormField="txtPhone" Name="phone" Type="String" />
        <asp:FormParameter FormField="txtContactID" Name="contactNo" Type="String" />
    </SelectParameters>
</asp:SqlDataSource>

存储过程如下。请注意,出于安全原因,我可能更改了上面的一些名称,但下面是原始字段。

ALTER PROCEDURE [dbo].[usp_GetContactIDs] 
    -- Add the parameters for the stored procedure here
    @companyname varchar(255) = NULL, 
    @firstname varchar(255) = NULL,
    @lastname varchar(255) = NULL,
    @phone varchar(10) = NULL,
    @contactid varchar(15) = NULL
AS
BEGIN
    -- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    SET NOCOUNT ON;
    Declare @sql varchar(1000);



    set @sql = 'select ID, companyname,contactfirstname,contactlastname,phonenumber, contactid from oet WHERE ID is not null'

    if(@companyname is not null)
        set @sql = @sql + ' AND companyname = '''+ @companyname + '''';

    if(@firstname is not null)
        set @sql = @sql + ' AND contactfirstname = '''+ @firstname + '''';

    if(@lastname is not null)
        set @sql = @sql + ' AND contactlastname = '''+ @lastname + '''';

    if(@phone is not null)
        set @sql = @sql + ' AND phonenumber = '''+ @phone + '''';

    if(@contactid is not null)
        set @sql = @sql + ' AND contactid = '''+ @contactid + '''';


    exec (@sql)


END

最佳答案

我花了一天多的时间才解决这个问题。 问题出在母版页。当我从页面中删除母版页时,一切正常。发生的情况是 txtFirstName 控件位于页面上,但自从我使用母版页以来从未找到它。结果它每次都传递一个空值。它没有产生任何错误(这是应该的),这使得调试非常棘手。

还有很多其他属性需要查看。重要的是

在 SQL 数据源中,配置数据源、参数部分:选择参数并单击“显示高级选项”、ConvertEmptyStringToNull。您可能需要将其更改为 false。

SQLDatasourc -> 属性 -> CancelSelectOnNullParamter = 将其更改为 false

关于asp.net - 在SQLDatasource中使用存储过程时,Gridview不显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7114122/

相关文章:

sql - 如何管理 SQL 源代码?

c# - ASP.NET GridView EditTemplate 和查找控件

c# - 从 Gridview 中的某些行隐藏图像按钮

oracle - 如何找出存储过程中使用了哪些表/ View /同义词

c# - 正则表达式控制中的双引号

asp.net - 重定向到 returnUrl 在 Asp.Net MVC5 中如何工作

asp.net - 多个RegisterClientScriptBlock的

sql - COALESCE 在 Where 子句中?

c# - 从 MySql 数据库收集数据后,我的 ASP.NET 应用程序不显示填充的 GridView

c# - 在 web.config 上设置 AD 角色名称