2009-11-17 4 views
5

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

データはストアドプロシージャから取得され、デフォルト値を持つ単一パラメータが使用されます。スキーマをリフレッシュするか「テストクエリ」をクリックすると、結果行が表示され、GridViewsフィールドがcorectly作成されます。しかし、私がページを実行するとグリッドビューは表示されません(EmptyDataTemplateを追加すると表示されます)。私はカスタム(空の)関数とDataBind、DataBinded、RowCretedイベントを追加しましたが、databindイベントとdatavoundイベントのみが起動されます(ただし、デフォルトパラメータの戻り値を持つストアドプロシージャと.netはデザインモード)

手順に「派手な」ものは何もありません。私はこれを何度も問題なく実行しました。私は別のストアドプロシージャのウィッヒは、当社の生産ENVで動作しようとしたし、まだここに同じ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 

     } 
    } 
} 

答えて

13

で選択を実行かどうかを確認するために、SQL Serverプロファイラをお試しください。これは、SelectParametersコレクションに含まれているパラメーターに、ConvertEmptyStringToNullがデフォルトでtrueに設定されているためです。また、既定では、SqlDataSourceのCancelSelectOnNullParameterはtrueに設定されています。これは、あなたの 'val2'パラメータがおそらくNULL値を渡していることを意味し、これはデータ検索操作を中止します。このため、SQLプロファイラ内でアクティビティが表示されません。

SqlDataSourceCancelSelectOnNullParameterをfalseに設定してみてください。

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

+1

私は感謝していません:) – SimSimY

+0

+1あなたは私を数時間節約しました! :) – meda

+1

ありがとう。 6年後、あなたは私を助けました:-) MSが混乱を生むためにそれをデフォルトで行うのはなぜか分かりません。 –

0

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

あなたはREALパラメータSelectCommandSqlDataSourceから発行されたときに、SQLプロファイラは、任意の活性を示していないかのように見えるあなたの最近のコメントから

+0

偶然には(第1、値なしのデフォルト値を持つ彼らが必要passas(あるストアドプロシージャ自体のデフォルト値を持つ) DBへの接続(がないように見えますプロファイラはBatchStartingイベントを表示しませんでしたが、私がmanagamnetスタジオから手順を実行したときに表示されました – SimSimY

関連する問題