数据来自存储过程,单个参数具有默认值。当我刷新架构或单击“测试查询”时,我看到结果行和GridViews字段是核心创建的。但是当我运行页面时,没有网格视图(它只是空的 - 当我添加EmptyDataTemplate时会显示它)。我添加了自定义(空)函数和DataBind,DataBinded和RowCreted事件,并且只触发了databind和datavound事件(尽管如我所写 - 存储过程及其默认参数返回行和.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>
和代码隐藏
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
}
}
}
答案 0 :(得分:14)
从最近的评论中看,当SelectCommand
发出SqlDataSource
时,SQL Profiler似乎没有显示任何活动。这可能是因为默认情况下ConvertEmptyStringToNull
在SelectParameters
集合中包含的参数上设置为true。此外,默认情况下,SqlDataSource上的CancelSelectOnNullParameter
设置为true。这意味着您的'val2'参数可能传递NULL值,从而取消数据检索操作。这就是您在SQL事件探查器中看不到任何活动的原因。
尝试在CancelSelectOnNullParameter
上将SqlDataSource
设为false。
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$
ConnectionStrings:myConnectionString %>" SelectCommand="myStoredProcedure"
SelectCommandType="StoredProcedure" CancelSelectOnNullParameter="False">
</asp:SqlDataSource>
答案 1 :(得分:0)
我没有看到参数赋值(val1,val2),因此默认启动将为string和int分配默认值并传递给SQL服务器。
尝试使用SQL Server Profiler查看是否使用REAL参数执行选择