пустой gridview, хотя sqldatasource имеет значения

У меня действительно странная ситуация. Я создал новую страницу aspx и без использования ЛЮБЫХ настраиваемых логических объектов (все, что создано с помощью мастеров визуальных студий) попытался создать представление сетки из sqldatasource.

Данные поступают из хранимой процедуры с единственным параметром, который имеет значение по умолчанию. когда я обновляю схему или нажимаю «тестовый запрос», я вижу, что строки результатов и поля GridViews создаются надлежащим образом. Но когда я запускаю страницу, сетки нет (она просто пуста - когда я добавляю EmptyDataTemplate, она отображается). Я добавил настраиваемую (пустую) функцию и событие DataBind, DataBinded и RowCreted, и запускаются только события привязки данных и обнаружения данных (хотя, как я уже писал, хранимая процедура с ее параметрами по умолчанию возвращает строки и .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

        }
    }
}

person SimSimY    schedule 17.11.2009    source источник


Ответы (2)


Судя по вашим недавним комментариям, SQL Profiler не показывает никакой активности, когда SelectCommand выдается из SqlDataSource. Это может быть связано с тем, что ConvertEmptyStringToNull по умолчанию имеет значение true для параметров, содержащихся в коллекции SelectParameters. Кроме того, по умолчанию для CancelSelectOnNullParameter в SqlDataSource установлено значение true. Это означает, что ваш параметр 'val2', вероятно, передает значение NULL, что, в свою очередь, отменяет операцию извлечения данных. Вот почему вы не видите никакой активности в SQL Profiler.

Попробуйте установить для CancelSelectOnNullParameter значение false на SqlDataSource.

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

person Phaedrus    schedule 17.11.2009
comment
Спасибо. 6 лет спустя вы мне помогли :-) Не знаю, почему MS делает это по умолчанию, чтобы создать беспорядок. - person Milind Thakkar; 06.09.2015

Я не видел назначения параметров (val1, val2), поэтому запуск по умолчанию назначит значение по умолчанию для строки и int и перейдет на SQL-сервер.

Попробуйте SQL Server Profiler, чтобы увидеть, выполняете ли вы выбор с РЕАЛЬНЫМИ параметрами.

person Dewfy    schedule 17.11.2009
comment
Параметры - это проходы, которые они должны (со значением по умолчанию для первого и без значения (имеет значение по умолчанию в самой хранимой процедуре). Похоже, что нет подключения к БД (профилировщик не отображал событие BatchStarting, но когда я выполнил процедура от студии манагамнет - появилась) - person SimSimY; 17.11.2009