SQL Server報表服務(SSRS)對於開發人員和用戶來說是一個非常有用的設計和浏覽報表的工具。但是 ,有些特性是在SSRS中沒有提供為直接可以使用的。 這些特性是開發人員和用戶經常需要的。
在一個報表中顯示服務器名稱或IP地址
當報表數據是運行在幾個報表服務器上時,用戶經常會搞錯。你可能有一個測試和開發環境,但是你 不知道你的報表數據是來自於哪個服務器。
很明顯,解決這個問題的一個方法是在報表中顯示報表服務器名稱或它的IP地址。不幸的是,沒有直 接的函數或方法來獲取服務器名稱。但是有這個工作環境。
在報表服務中,有一個全局參數叫做ReportServerUrl,它可以顯示報表URL。這個值的開始部分是來 自於C:\Program Files\Microsoft SQL Server\MSSQL.#\Reporting Services\ReportServer 文件夾下的 RSReportServer.config 文件。在這個文件裡,有叫做URLRoot 的結點。它是http:// {IPAddress}/reportserver或http://{Server Name}/reportserver。你需要找到方法來提取這個IP地址 或服務器名稱,你可以使用下面的表達式:
Mid(Globals!ReportServerUrl,8,InStr(9,Globals!ReportServerUrl,"/")-8)
這個表達式所做的,是提取從//位置後的字母到/位置後的字母間的名稱,這是服務器的服務器名稱或 IP地址。
將數字類型轉化為文本
這是在SSRS論壇上經常看到的問題,因為許多用戶需要將數字類型的數據顯示為文本。盡管在水晶報 表中有一個函數,但是在SSRS中沒有函數。不過,你可以在SSRS中自己寫個函數。
讓我們用下面的查詢來舉個例子:
SELECT Sales.SalesPerson.SalesPersonID AS SalesPerson,
SUM(Sales.SalesOrderDetail.OrderQty * Sales.SalesOrderDetail.UnitPrice) AS Amount
FROM Sales.SalesOrderDetail
INNER JOIN Sales.SalesOrderHeader ON Sales.SalesOrderDetail.SalesOrderID = Sales.SalesOrderHeader.SalesOrderID
INNER JOIN Sales.SalesPerson ON Sales.SalesOrderHeader.SalesPersonID = Sales.SalesPerson.SalesPersonID
GROUP BY Sales.SalesPerson.SalesPersonID
為了使用這個例子,讓我們假設我們需要顯示銷售人員的id和數量,數量要以文本形式顯示。