翻譯|使用教程|編輯:王香|2018-08-22 09:55:39.000|閱讀 508 次
概述:本文詳細介紹了如何在FastReport.Net中使用SQL函數,以及表函數返回表,標量函數返回單個值。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
【下載FastReport.Net最新版本】
要在MS SQL中獲取數據,可以使用sql查詢,存儲過程和存儲函數,之前我們已經討論了如何使用動態查詢和存儲過程作為報表數據源,在本文中,我們將創建一個表和標量函數,并在報表中使用它們,表函數返回表,標量函數返回單個值。首先,在MS SQL中創建一個表函數:
USE [testdb] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Description: Returns customers who live in the specified city -- ============================================= CREATE FUNCTION [dbo].[GetCustomersFromCity] ( @city VARCHAR(20) ) RETURNS TABLE AS RETURN ( SELECT * FROM dbo.CUSTOMER WHERE CITY = @city )
該函數采用一個參數——城市名稱,并返回此城市中的客戶列表。再添加一個現在的標量函數:
USE [testdb] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO -- ============================================= -- Description: Returns last added customer -- ============================================= CREATE FUNCTION [dbo].[GetLastCustomer] () RETURNS VARCHAR(30) AS BEGIN DECLARE @Name VARCHAR(30) SELECT TOP 1 @Name = CONCAT(ind.FIRST_NAME, ' ', ind.LAST_NAME) FROM dbo.Customer cus JOIN dbo.Individual ind ON ind.CUST_ID = cus.CUST_ID ORDER BY cus.CUST_ID RETURN @Name END
此函數不接受參數,但返回最后注冊的客戶端名稱。現在讓我們繼續查看報表。首先,在報表中創建一個參數,我們將使用它將城市名稱轉移到函數,以檢索數據。
添加到MS SQL數據庫的連接:
然后,在下一步中,我們被要求選擇表,但我們將使用Add SQL query ...按鈕
在下一步中,設置新表的名稱——TableFunction,點擊Next:
與存儲過程不同,函數用作表,也就是說,需要使用Select來獲取數據:
在下一步中,我們需要添加city查詢參數,在其Expression屬性中,選擇報表的Param參數,單擊Finish,得到一個新的數據源:
現在添加對話框窗體并將報表的Param參數拖到它上面,將字段從TableFunction表拖到Data band,運行報表,在對話框中輸入值:
從表函數中獲取樣本:
文章開頭我們創建了兩個函數,這個例子更簡單,因為我沒有向這個函數添加一個傳入參數。讓我們再創建一個數據源,另外,至于第一次——connection to MS SQL,再次單擊Add SQL query ...按鈕,調用標量函數與調用表函數略有不同:
跳過所有其他步驟:
再添加一頁報表并將數據拖動到新數據源的單個字段——ScalarFunc,運行報表,轉到第二頁:
如上所示,使用函數獲取數據非常簡單,它們將幫助您在開發報表及其執行時節省時間。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn