程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL Server報表服務中的一些常見小問題

SQL Server報表服務中的一些常見小問題

編輯:關於SqlServer

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和數量,數量要以文本形式顯示。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved