Share via


使用報表資料集中的欄位 (報表產生器 3.0 和 SSRS)

資料集欄位代表資料連接中的資料。欄位可以代表數值或非數值資料。範例包括銷售量、總銷售額、客戶名稱、資料庫識別碼、URL、影像、空間資料及電子郵件地址。在設計介面上,欄位會以報表項目 (如文字方塊、資料表和圖表) 中的運算式形式出現。

報表擁有三種類型的欄位,而且會將其顯示於 [報表資料] 窗格中:資料集欄位、資料集導出欄位和內建欄位。

  • **資料集欄位。**代表欄位集合的中繼資料,當針對資料來源執行資料集查詢時,將會傳回這些欄位。

  • **資料集導出欄位。**您針對資料集建立的其他欄位。每一個導出欄位的建立方式都是藉由評估您所定義的運算式。

  • **內建欄位。**代表報表產生器所提供之欄位集合的中繼資料,這些欄位會在處理報表時提供報表資訊,例如報表名稱或時間。如需詳細資訊,請參閱<使用內建的全域和使用者參考 (報表產生器 3.0 和 SSRS)>。

資料集欄位名稱會當做報表資料集定義的一部分來儲存。如需詳細資訊,請參閱<建立與加入資料集 (報表產生器 3.0 和 SSRS)>。

[!附註]

您可以在 Business Intelligence Development Studio 中的報表產生器 3.0 及報表設計師中建立及修改報表定義 (.rdl)。每一個撰寫環境都提供了不同的方式讓您建立、開啟,以及儲存報表和相關的項目。如需詳細資訊,請參閱在報表設計師及報表產生器 3.0 (SSRS) 中設計報表,位於 microsoft.com 網站上。

本文內容

資料集欄位和查詢

了解欄位的預設運算式

資料集欄位和資料類型

在執行階段偵測遺漏的欄位

資料集欄位和查詢

資料集欄位是由資料集查詢命令以及您所定義之任何導出欄位所指定。您在報表中看到的欄位集合取決於您具有的資料集類型:

  • **共用資料集。**欄位集合是當您直接將共用資料集加入報表,或是當您加入的報表組件已包含共用資料集時,共用資料集定義內查詢的欄位清單。當報表伺服器上的共用資料集定義變更時,本機欄位集合將不會變更。若要更新本機欄位集合,您必須重新整理本機共用資料集的清單。

  • **內嵌資料集。**欄位集合是針對資料來源執行目前的查詢時所傳回的欄位清單。

如需詳細資訊,請參閱<如何:加入、編輯、重新整理報表資料窗格中的欄位 (報表產生器 3.0 和 SSRS)

如果您在資料集欄位集合中沒有看到預期的結果,請參閱<報表疑難排解:報表資料擷取>。

搭配回到頁首連結使用的箭頭圖示回到頁首

導出欄位

您可藉由建立運算式來手動指定導出欄位。導出欄位可用來建立不存在於資料來源上的新值。例如,導出欄位可代表新值、一組欄位值的自訂排序次序,或是轉換成另一個資料類型的現有欄位。

導出欄位在報表的本機,而且不能儲存為共用資料集的一部分。

如需詳細資訊,請參閱<如何:加入、編輯、重新整理報表資料窗格中的欄位 (報表產生器 3.0 和 SSRS)>。

搭配回到頁首連結使用的箭頭圖示回到頁首

實體和實體欄位

如果您正在處理報表模型資料來源,您可將實體和實體欄位指定為報表資料。在報表模型的查詢設計工具中,您可以透過互動方式來瀏覽及選取相關實體,並選擇您要併入報表資料集的欄位。當您完成查詢的設計之後,您可以在 [報表資料] 窗格內查看實體識別碼和實體欄位的集合。實體識別碼是由報表模型自動產生,通常不會對使用者顯示。如需詳細資訊,請參閱<報表模型查詢設計工具使用者介面 (報表產生器 3.0)>。

使用擴充欄位屬性

支援多維度查詢的資料來源 (如 SQL Server Analysis Services) 可支援欄位上的欄位屬性。欄位屬性會出現在查詢的結果集中,但是在 [報表資料] 窗格中則看不到。欄位屬性仍然可供您的報表使用。若要參考欄位的屬性,請將欄位拖曳到報表上,然後將預設屬性 Value 變更為您想要之屬性的欄位名稱。例如在 Analysis Services Cube 中,您可以針對 Cube 資料格中的值來定義格式。可以使用欄位屬性 FormattedValue 來取得格式化的值。若要直接使用該值,而不是使用值並設定文字方塊的格式屬性,請將欄位拖曳到文字方塊,並將預設運算式 =Fields!FieldName.Value 變更為 =Fields!FieldName.FormattedValue。

[!附註]

並非所有 Field 屬性都可用於所有資料來源。Value 和 IsMissing 屬性是為所有資料來源定義的。其他預先定義的屬性 (例如多維度資料來源的 Key、UniqueName 和 ParentUniqueName) 只有在資料來源有提供這些屬性時,才受到支援。某些資料提供者可支援自訂屬性。如需詳細資訊,請參閱<建立與加入資料集 (報表產生器 3.0 和 SSRS)>中有關適用於資料來源類型之擴充欄位屬性的特定主題。例如,如果是 SQL Server Analysis Services 資料來源,請參閱<Analysis Services 資料庫的擴充欄位屬性 (SSRS)>。

搭配回到頁首連結使用的箭頭圖示回到頁首

了解欄位的預設運算式

文字方塊可以是報表主體中的文字方塊報表項目,或是 Tablix 資料區資料格中的文字方塊。當您將欄位與文字方塊連結時,文字方塊的位置會決定欄位參考的預設運算式。在報表主體中,文字方塊值運算式必須指定彙總和資料集。如果報表中只有一個資料集存在,系統會為您建立這個預設運算式。如果是代表數值的欄位,預設彙總函式為 Sum。如果是代表非數值的欄位,預設彙總函式為 First。

在 Tablix 資料區中,預設欄位運算式取決於您加入欄位之文字方塊的資料列和群組成員資格。Sales 欄位的欄位運算式 (當加入到資料表之詳細資料列中的文字方塊時) 為 [Sales]。如果您將相同的欄位加入到群組首中的文字方塊,預設運算式就是 (Sum[Sales]),因為群組首會顯示群組的摘要值,而非詳細資料值。當報表執行時,報表處理器會評估每一個運算式,並替代報表中的結果。

如需有關運算式的詳細資訊,請參閱<運算式 (報表產生器 3.0 和 SSRS)>。

搭配回到頁首連結使用的箭頭圖示回到頁首

欄位資料類型

當您建立資料集時,資料來源上欄位的資料類型可能不完全是報表中使用的資料類型。資料類型可能會經歷一或兩個對應層。資料處理延伸模組或資料提供者可以將資料來源中的資料類型對應到 Common Language Runtime (CLR) 資料類型。資料處理延伸模組所傳回的資料類型會從 .NET Framework 對應到 Common Language Runtime (CLR) 資料類型的子集。

在資料來源上,資料會使用此資料來源所支援的資料類型來儲存。例如,SQL Server 資料庫中的資料必須是其中一個支援的 SQL Server 資料類型,例如 nvarchar 或 datetime。當您從此資料來源擷取資料時,資料會透過與資料來源類型相關聯的資料處理延伸模組或資料提供者來傳遞。根據資料處理延伸模組,資料可以從資料來源所使用的資料類型轉換成資料處理延伸模組所支援的資料類型。Reporting Services 會使用與 Business Intelligence Development Studio 一起安裝之 Common Language Runtime (CLR) 所支援的資料類型。資料提供者會將結果集中的每一個資料行從原生資料類型對應到 .NET Framework Common Language Runtime (CLR) 資料類型。

在每一個階段,資料都是由資料類型來表示,如以下清單所述:

  • 資料來源:您所連接之資料來源類型版本所支援的資料類型。

    例如,適用於 SQL Server 資料來源的一般資料類型包括 int、datetime 和 varchar。SQL Server 2008 所導入的資料類型已經加入 date、time、datetimetz 和 datetime2 的支援。如需詳細資訊,請參閱<資料類型 (Transact-SQL)>。

  • 資料提供者或資料處理延伸模組:當您連接到資料來源時,您所選取之資料處理延伸模組的資料提供者版本所支援的資料類型。以 .NET Framework 為基礎的資料提供者會使用 CLR 所支援的資料類型。如需有關 .NET Framework 資料提供者資料類型的詳細資訊,請參閱 MSDN上的<資料型別對應 (ADO.NET)>和<使用基底型別>。

    例如,.NET Framework 所支援的一般資料類型包括 Int32 和 String。DateTime 結構支援日曆上的日期和時間。.NET Framework 2.0 Service Pack 1 針對具有時區時差的日期導入了 DateTimeOffset 結構的支援。

    [!附註]

    報表伺服器會使用報表伺服器上所安裝及設定的資料提供者。[預覽] 模式下的報表撰寫用戶端會使用用戶端電腦上所安裝及設定的資料處理延伸模組。您必須同時在報表用戶端和報表伺服器環境下測試您的報表。

  • 報表處理器:資料類型是以您安裝 Reporting Services 時所安裝的 CLR 版本為基礎。SQL Server 2008 Reporting Services 會安裝以 .NET Framework 3.5 為基礎的 CLR。

    例如,SQL Server 2008 已導入報表處理器用於新日期和時間類型的日期類型,如下表所示:

    SQL 資料類型

    CLR 資料類型

    說明

    Date

    DateTime

    僅限日期

    Time

    TimeSpan

    僅限時間

    DateTimeTZ

    DateTimeOffset

    包含時區時差的日期和時間

    DateTime2

    DateTime

    包含毫秒的日期和時間

如需有關 SQL Server 資料庫類型的詳細資訊,請參閱資料類型 (Database Engine)日期和時間資料類型與函數 (Transact-SQL)

如需有關從運算式加入資料集欄位之參考的詳細資訊,請參閱<在運算式中使用資料類型 (報表產生器 3.0 和 SSRS)>。

搭配回到頁首連結使用的箭頭圖示回到頁首

在執行階段偵測遺漏的欄位

當報表處理時,資料集的結果集可能不包含指定之所有資料行的值,因為資料行不再存在於資料來源中。您可以使用欄位屬性 IsMissing 來偵測是否在執行階段傳回欄位的值。如需詳細資訊,請參閱<使用資料集欄位集合參考 (報表產生器 3.0 和 SSRS)>。

搭配回到頁首連結使用的箭頭圖示回到頁首