5

私は本当に奇妙な状況にあります。新しいaspxページを作成しましたが、カスタムロジックオブジェクト(Visual Studioウィザードで作成されたものすべて)を使用せずに、sqldatasourceからグリッドビューを作成しようとしました。

データはストアドプロシージャから取得され、デフォルト値を持つ単一のパラメータがあります。スキーマを更新するか、[クエリのテスト]をクリックすると、結果の行とGridViewsフィールドが正しく作成されていることがわかります。しかし、ページを実行するとグリッドビューが表示されません(単に空です。EmptyDataTemplateを追加すると表示されます)。カスタム(空)関数とDataBind、DataBinded、およびRowCretedイベントを追加しましたが、databindイベントとdatavoundイベントのみが発生します(ただし、私が書いたように、デフォルトのパラメーターを持つストアドプロシージャは行を返し、.netはそれらをデザインモードで読み取ることができます)。

手順には「派手な」ものは何もありません。私はこれを何度も問題なく実行しました。本番環境で機能する別のストアドプロシージャを試しましたが、同じ空のグリッドビューが表示されます

これがコードです

<%@ 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

        }
    }
}
4

2 に答える 2

14

SelectCommand最近のコメントから、 が から発行されたときに SQL プロファイラーがアクティビティを表示していないように見えますSqlDataSource。これは、コレクションConvertEmptyStringToNullに含まれるパラメーターでデフォルトで true に設定されていることが原因である可能性があります。SelectParametersまた、デフォルトではCancelSelectOnNullParameter、SqlDataSource の は true に設定されています。これは、「val2」パラメーターがおそらく NULL 値を渡していることを意味し、これによりデータ取得操作がキャンセルされます。これが、SQL プロファイラー内でアクティビティが表示されない理由です。

CancelSelectOnNullParameterで false に設定してみてくださいSqlDataSource

<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:myConnectionString %>" SelectCommand="myStoredProcedure" SelectCommandType="StoredProcedure" CancelSelectOnNullParameter="False"> </asp:SqlDataSource>

于 2009-11-17T18:54:34.983 に答える
0

パラメータ(val1、val2)の割り当てが表示されていないため、デフォルトの起動により、stringとintにデフォルトが割り当てられ、SQLサーバーに渡されます。

SQL Server Profilerを試して、REALパラメーターを使用して選択を実行するかどうかを確認してください

于 2009-11-17T15:50:57.803 に答える