c# - 空的gridview雖然sqldatasource有值




asp.net (2)

我真的很奇怪 我已經創建了新的aspx頁面,並且沒有使用任何自定義邏輯對象(所有使用visual studio嚮導創建的對象)試圖從sqldatasource創建網格視圖。

數據來自存儲過程,具有默認值的單個參數。 當我刷新架構或單擊“測試查詢”,我看到結果行和GridViews字段被正確地創建。 但是,當我運行的頁面沒有網格視圖(它只是空的 - 當我添加EmptyDataTemplate它顯示)。 我已經添加了自定義(空)函數和DataBind,DataBinded和RowCreted事件,並且只激發了數據綁定和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

        }
    }
}

從最近的評論看,當從SqlDataSource發出SelectCommand時,SQL Profiler不顯示任何活動。 這可能是由於SelectParameters集合中包含的參數默認情況下ConvertEmptyStringToNull設置為true。 此外,默認情況下,SqlDataSource上的CancelSelectOnNullParameter設置為true。 這意味著你的'val2'參數可能會傳遞一個NULL值,從而取消數據檢索操作。 這就是為什麼在SQL Profiler中看不到任何活動。

嘗試在SqlDataSource CancelSelectOnNullParameter設置為false。

<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$


我沒有看到參數(val1,val2)的賦值,所以默認的啟動會為string和int賦值,並傳遞給SQL服務器。

嘗試使用SQL Server Profiler查看是否使用REAL參數執行選擇