C# 尽管sqldatasource具有值,但gridview为空

C# 尽管sqldatasource具有值,但gridview为空,c#,asp.net,gridview,sqldatasource,C#,Asp.net,Gridview,Sqldatasource,我的处境真的很奇怪。 我已经创建了新的aspx页面,并且在不使用任何自定义逻辑对象(使用visual Studio向导创建的所有对象)的情况下,尝试从sqldatasource创建网格视图 数据来自存储过程,只有一个参数具有默认值。当我刷新模式或单击“测试查询”时,我看到结果行和GridView字段被正确创建。但是当我运行页面时,没有网格视图(它只是空的——当我添加EmptyDataTemplate时,它会显示出来)。我已经添加了自定义(空)函数和DataBind、DataInded和RowCr

我的处境真的很奇怪。 我已经创建了新的aspx页面,并且在不使用任何自定义逻辑对象(使用visual Studio向导创建的所有对象)的情况下,尝试从sqldatasource创建网格视图

数据来自存储过程,只有一个参数具有默认值。当我刷新模式或单击“测试查询”时,我看到结果行和GridView字段被正确创建。但是当我运行页面时,没有网格视图(它只是空的——当我添加EmptyDataTemplate时,它会显示出来)。我已经添加了自定义(空)函数和DataBind、DataInded和RowCreted事件,并且只触发DataBind和datavound事件(尽管,正如我所写的,具有默认参数return rows和.net的存储过程可以在设计模式下读取它们)

在这个过程中没有任何“幻想”,我已经做了不止一次,没有任何问题。我尝试了另一个在我们的生产环境中工作的存储过程,但仍然得到了相同的emty gridview

这是密码

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="TEST.aspx.cs" Inherits="site.TEST" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server" DataSourceID="SqlDataSource1"
            AllowSorting="True" OnDataBinding="GridView1_DataBinding" OnDataBound="GridView1_DataBound"
            OnRowCreated="GridView1_RowCreated">
            <EmptyDataTemplate>
                No Data Available
            </EmptyDataTemplate>
        </asp:GridView>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:myConnectionString %>"
            SelectCommand="myStoredProcedure" SelectCommandType="StoredProcedure">
            <SelectParameters>
                <asp:Parameter DefaultValue="val1" Name="par1" Type="String" />
                <asp:Parameter Name="val2" Type="Int32" />
            </SelectParameters>
        </asp:SqlDataSource>
    </div>
    </form>
</body>
</html>

我还没有看到参数的赋值(val1,val2),所以默认启动将为string和int分配default,并传递给SQLServer


请尝试使用SQL Server Profiler查看您是否使用您最近的评论中的真实参数执行选择。从
SqlDataSource
发出
SelectCommand
时,SQL Profiler似乎没有显示任何活动。这可能是因为
SelectParameters
集合中包含的参数默认情况下将
convertEmptyStringToFull
设置为true。此外,默认情况下,SqlDataSource上的
CancelSelectOnNullParameter
设置为true。这意味着您的“val2”参数可能正在传递NULL值,这反过来会取消数据检索操作。这就是为什么在SQL事件探查器中看不到任何活动

尝试将
SqlDataSource
上的
CancelSelectOnNullParameter
设置为false


参数是应该的(第一个参数有默认值,没有值(存储过程本身有默认值),看起来与数据库没有连接(探查器没有显示BatchStarting事件,但当我从managamnet studio执行过程时,它出现了)谢谢。6年后,你帮了我:-)不知道为什么微软会在默认情况下这样做,制造混乱。
using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

namespace site
{
    public partial class TEST : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {//brake here

        }

        protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e)
        {//brake here

        }

        protected void GridView1_DataBinding(object sender, EventArgs e)
        {//brake here

        }

        protected void GridView1_DataBound(object sender, EventArgs e)
        {//brake here

        }
    }
}