• <menu id="w2i4a"></menu>
  • logo Fastreport.Net 教程2018(完結(jié))

    文檔首頁>>Fastreport.Net 教程2018(完結(jié))>>如何在FastReport.Net中使用SQL函數(shù)

    如何在FastReport.Net中使用SQL函數(shù)


    【下載FastReport.Net最新版本】

    要在MS SQL中獲取數(shù)據(jù),可以使用sql查詢,存儲過程和存儲函數(shù),之前我們已經(jīng)討論了如何使用動態(tài)查詢和存儲過程作為報表數(shù)據(jù)源,在本文中,我們將創(chuàng)建一個表和標(biāo)量函數(shù),并在報表中使用它們,表函數(shù)返回表,標(biāo)量函數(shù)返回單個值。首先,在MS SQL中創(chuàng)建一個表函數(shù):

    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
    )

    該函數(shù)采用一個參數(shù)——城市名稱,并返回此城市中的客戶列表。再添加一個現(xiàn)在的標(biāo)量函數(shù):

    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

    此函數(shù)不接受參數(shù),但返回最后注冊的客戶端名稱。現(xiàn)在讓我們繼續(xù)查看報表。首先,在報表中創(chuàng)建一個參數(shù),我們將使用它將城市名稱轉(zhuǎn)移到函數(shù),以檢索數(shù)據(jù)。

    VectorBarcodes

    添加到MS SQL數(shù)據(jù)庫的連接:

    VectorBarcodes

    然后,在下一步中,我們被要求選擇表,但我們將使用Add SQL query ...按鈕

    VectorBarcodes

    在下一步中,設(shè)置新表的名稱——TableFunction,點擊Next:

    VectorBarcodes

    與存儲過程不同,函數(shù)用作表,也就是說,需要使用Select來獲取數(shù)據(jù):

    VectorBarcodes

    在下一步中,我們需要添加city查詢參數(shù),在其Expression屬性中,選擇報表的Param參數(shù),單擊Finish,得到一個新的數(shù)據(jù)源:

    VectorBarcodes

    現(xiàn)在添加對話框窗體并將報表的Param參數(shù)拖到它上面,將字段從TableFunction表拖到Data band,運行報表,在對話框中輸入值:

    VectorBarcodes

    從表函數(shù)中獲取樣本:

    VectorBarcodes

    文章開頭我們創(chuàng)建了兩個函數(shù),這個例子更簡單,因為我沒有向這個函數(shù)添加一個傳入?yún)?shù)。讓我們再創(chuàng)建一個數(shù)據(jù)源,另外,至于第一次——connection to MS SQL,再次單擊Add SQL query ...按鈕,調(diào)用標(biāo)量函數(shù)與調(diào)用表函數(shù)略有不同:

    VectorBarcodes

    跳過所有其他步驟:

    VectorBarcodes

    再添加一頁報表并將數(shù)據(jù)拖動到新數(shù)據(jù)源的單個字段——ScalarFunc,運行報表,轉(zhuǎn)到第二頁:

    VectorBarcodes

    如上所示,使用函數(shù)獲取數(shù)據(jù)非常簡單,它們將幫助您在開發(fā)報表及其執(zhí)行時節(jié)省時間。

    FastReport教程合集
    掃碼咨詢


    添加微信 立即咨詢

    電話咨詢

    客服熱線
    023-68661681

    TOP
    三级成人熟女影院,欧美午夜成人精品视频,亚洲国产成人乱色在线观看,色中色成人论坛 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();