SSRS 下载所有历史快照

发布于 2025-01-11 15:55:58 字数 245 浏览 0 评论 0原文

是否可以一次性下载一份报表的所有历史快照?最好是 CSV 格式。与单独单击每个选项并选择“另存为 CSV”相比,可以节省大量时间。

我只看到删除

SSRS 历史快照窗口的片段

Is it possible to download all the history snapshots of a report at once? Preferably as a CSV. Would save a lot time instead of clicking into each one individually and selecting save as CSV.

I only see the option to Delete

snip of SSRS history snapshot window

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

作死小能手 2025-01-18 15:55:58

在 PowerShell 中,您可以循环遍历每个快照并使用以下示例保存它们:

<#
    Description: Save SSRS Report Snapshots

#>

$sql = "
    DECLARE @ReportName    NVARCHAR(200) = 'Your Report Name'; --change to NULL for every snapshot
    DECLARE @FileFormat    NVARCHAR(50) = 'CSV'; --HTML5,PPTX,ATOM,HTML4.0,MHTML,IMAGE,EXCEL (for .xls),EXCELOPENXML (for .xlsx),WORD (for .doc),WORDOPENXML (for .docx),CSV,PDF,XML
    DECLARE @FileExtn      NVARCHAR(50) = 'csv'; 
    DECLARE @ServerName    NVARCHAR(100) = 'http://YourServerName';
    DECLARE @DateFrom      DATE = CAST(DATEADD(DAY, -1, GETDATE()) AS DATE); --change to NULL for every snapshot
    DECLARE @ExportPath    NVARCHAR(200) = 'C:\Temp\';

    SELECT 
        --[ReportID] = [c].[itemid]  
     --  , [ReportName] = [c].[name]  
     --  , [ReportPath] = [c].[path]  
     --  , [SnaphsotDate] = FORMAT([h].[snapshotdate], 'dd-MMM-yyyy')
     --  , [SnapshotDescription] = [s].[DESCRIPTION]  
     --  , [SnapshotEffectiveParams] = [s].[effectiveparams]
     --  , [SnapshotQueryParams] = [s].[queryparams]
     --  , [ScheduleName] = [sc].[name] 
     --  , [ScheduleNextRunTime] = CONVERT(VARCHAR(20), [sc].[nextruntime], 113) 
         [ExportFileName] = @ExportPath + REPLACE([c].[name], ' ', '_') + '_' + FORMAT([h].[snapshotdate], 'yyyyMMdd_HHmm') + '.' + @FileExtn
       , [SnapshotUrl] = 
            @ServerName 
          + '/ReportServer/Pages/ReportViewer.aspx?' 
          + [c].[path] + '&rs:Command=Render&rs:Format=' 
          + @FileFormat + '&rs:Snapshot=' 
          + FORMAT([h].[snapshotdate], 'yyyy-MM-ddTHH:mm:ss')
    FROM
        [ReportServer].[dbo].[History] AS [h] WITH(NOLOCK)
        INNER JOIN [ReportServer].[dbo].[SnapshotData] AS [s] WITH(NOLOCK) ON [h].[snapshotdataid] = [s].[snapshotdataid]
        INNER JOIN [ReportServer].[dbo].[Catalog] AS [c] WITH(NOLOCK) ON [c].[itemid] = [h].[reportid]
        INNER JOIN [ReportServer].[dbo].[ReportSchedule] AS [rs] WITH(NOLOCK) ON [rs].[reportid] = [h].[reportid]
        INNER JOIN [ReportServer].[dbo].[Schedule] AS [sc] WITH(NOLOCK) ON [sc].[scheduleid] = [rs].[scheduleid]
    WHERE
       1=1
       AND [rs].[reportaction] = 2 
       AND (@ReportName IS NULL OR [c].[Name] = @ReportName)
       AND (@DateFrom IS NULL OR [h].[snapshotdate] >= CAST(DATEADD(DAY, -1, GETDATE()) AS DATE))
    ORDER BY 
         [c].[name]
       , [h].[snapshotdate];
                        ;"

    $server = 'YourServerName'; 
    $dbs = 'MASTER';
    $dsn = "Data Source=$server; Initial Catalog=$dbs; Integrated Security=SSPI;"; 
    $cn = New-Object System.Data.SqlClient.SqlConnection($dsn); 

    #execute merge statement here with parameters
    $cn = New-Object System.Data.SqlClient.SqlConnection($dsn);
    $cn.Open(); 

    $cmd = $cn.CreateCommand();
    $cmd.CommandText = $sql
    $SqlAdapter = New-Object System.Data.SqlClient.SqlDataAdapter
    $SqlAdapter.SelectCommand = $cmd
    $cmd.Connection = $cn
    $ds = New-Object System.Data.DataSet
    $SqlAdapter.Fill($ds)
    $cn.Close()
    $Result = $ds.Tables[0]

    Foreach ($item in $Result) 
    {
        #Write-Host $item.name

        $SnapshotUrl = $item.SnapshotUrl
        $ExportFileName = $item.ExportFileName
        (Invoke-WebRequest -Uri $SnapshotUrl -OutFile $ExportFileName -UseDefaultCredentials -TimeoutSec 240);
    }

https://learn.microsoft.com/en-us/sql/reporting-services/url-access-parameter-reference?view=sql-server-ver15

In PowerShell, you can loop through each snapshot and save them using this example:

<#
    Description: Save SSRS Report Snapshots

#>

$sql = "
    DECLARE @ReportName    NVARCHAR(200) = 'Your Report Name'; --change to NULL for every snapshot
    DECLARE @FileFormat    NVARCHAR(50) = 'CSV'; --HTML5,PPTX,ATOM,HTML4.0,MHTML,IMAGE,EXCEL (for .xls),EXCELOPENXML (for .xlsx),WORD (for .doc),WORDOPENXML (for .docx),CSV,PDF,XML
    DECLARE @FileExtn      NVARCHAR(50) = 'csv'; 
    DECLARE @ServerName    NVARCHAR(100) = 'http://YourServerName';
    DECLARE @DateFrom      DATE = CAST(DATEADD(DAY, -1, GETDATE()) AS DATE); --change to NULL for every snapshot
    DECLARE @ExportPath    NVARCHAR(200) = 'C:\Temp\';

    SELECT 
        --[ReportID] = [c].[itemid]  
     --  , [ReportName] = [c].[name]  
     --  , [ReportPath] = [c].[path]  
     --  , [SnaphsotDate] = FORMAT([h].[snapshotdate], 'dd-MMM-yyyy')
     --  , [SnapshotDescription] = [s].[DESCRIPTION]  
     --  , [SnapshotEffectiveParams] = [s].[effectiveparams]
     --  , [SnapshotQueryParams] = [s].[queryparams]
     --  , [ScheduleName] = [sc].[name] 
     --  , [ScheduleNextRunTime] = CONVERT(VARCHAR(20), [sc].[nextruntime], 113) 
         [ExportFileName] = @ExportPath + REPLACE([c].[name], ' ', '_') + '_' + FORMAT([h].[snapshotdate], 'yyyyMMdd_HHmm') + '.' + @FileExtn
       , [SnapshotUrl] = 
            @ServerName 
          + '/ReportServer/Pages/ReportViewer.aspx?' 
          + [c].[path] + '&rs:Command=Render&rs:Format=' 
          + @FileFormat + '&rs:Snapshot=' 
          + FORMAT([h].[snapshotdate], 'yyyy-MM-ddTHH:mm:ss')
    FROM
        [ReportServer].[dbo].[History] AS [h] WITH(NOLOCK)
        INNER JOIN [ReportServer].[dbo].[SnapshotData] AS [s] WITH(NOLOCK) ON [h].[snapshotdataid] = [s].[snapshotdataid]
        INNER JOIN [ReportServer].[dbo].[Catalog] AS [c] WITH(NOLOCK) ON [c].[itemid] = [h].[reportid]
        INNER JOIN [ReportServer].[dbo].[ReportSchedule] AS [rs] WITH(NOLOCK) ON [rs].[reportid] = [h].[reportid]
        INNER JOIN [ReportServer].[dbo].[Schedule] AS [sc] WITH(NOLOCK) ON [sc].[scheduleid] = [rs].[scheduleid]
    WHERE
       1=1
       AND [rs].[reportaction] = 2 
       AND (@ReportName IS NULL OR [c].[Name] = @ReportName)
       AND (@DateFrom IS NULL OR [h].[snapshotdate] >= CAST(DATEADD(DAY, -1, GETDATE()) AS DATE))
    ORDER BY 
         [c].[name]
       , [h].[snapshotdate];
                        ;"

    $server = 'YourServerName'; 
    $dbs = 'MASTER';
    $dsn = "Data Source=$server; Initial Catalog=$dbs; Integrated Security=SSPI;"; 
    $cn = New-Object System.Data.SqlClient.SqlConnection($dsn); 

    #execute merge statement here with parameters
    $cn = New-Object System.Data.SqlClient.SqlConnection($dsn);
    $cn.Open(); 

    $cmd = $cn.CreateCommand();
    $cmd.CommandText = $sql
    $SqlAdapter = New-Object System.Data.SqlClient.SqlDataAdapter
    $SqlAdapter.SelectCommand = $cmd
    $cmd.Connection = $cn
    $ds = New-Object System.Data.DataSet
    $SqlAdapter.Fill($ds)
    $cn.Close()
    $Result = $ds.Tables[0]

    Foreach ($item in $Result) 
    {
        #Write-Host $item.name

        $SnapshotUrl = $item.SnapshotUrl
        $ExportFileName = $item.ExportFileName
        (Invoke-WebRequest -Uri $SnapshotUrl -OutFile $ExportFileName -UseDefaultCredentials -TimeoutSec 240);
    }

https://learn.microsoft.com/en-us/sql/reporting-services/url-access-parameter-reference?view=sql-server-ver15

梦在深巷 2025-01-18 15:55:58

在使用 powershell 时遇到问题,所以我想发布我的粗略 Python 解决方案的简化版本,灵感来自 @aduguid 答案的资源。

import requests
from requests_negotiate_sspi import HttpNegotiateAuth
import os

def downloadFile(url, file_name, download_folder, session):
    response = session.get(url, stream=True) # open the download link
    file_path = os.path.join(download_folder, file_name)
    with open(file_path, 'wb') as file: # create a new file with write binary mode
        for chunk in response.iter_content(chunk_size=1024):
            if chunk:
                file.write(chunk)

# Can also use '/Reports()' for non-linked reports.
# Can also pass in 'path="<report_path>"' instead of using id numbers,
# e.g. '.../Reports(path="/cool%20reports/my%20report")/HistorySnapshots'
api_url = r'http://<server_name>/reports/api/v2.0/LinkedReports(<item_id>)/HistorySnapshots'
session = requests.session()
session.auth = HttpNegotiateAuth() # uses windows log in
response = session.get(api_url)
hs_snapshot_list = response.json()['value']

for item_dict in hs_snapshot_list:
    download_url = (r'http://<server_name>/ReportServer/Pages/ReportViewer.aspx?<report_path>'
                    + '&rs:Snapshot=' + item_dict['HistoryId']
                    + '&rs:Format=CSV')
    downloadFile(download_url, '<your_file_name>', '<your_download_folder>', session)

SSRS API 资源:
https://app.swaggerhub.com/apis/microsoft -rs/SSRS/2.0#/Reports/GetReportHistorySnapshots

Was having trouble with powershell, so thought I'd post simplified version of my rough Python solution inspired by the resource from @aduguid's answer.

import requests
from requests_negotiate_sspi import HttpNegotiateAuth
import os

def downloadFile(url, file_name, download_folder, session):
    response = session.get(url, stream=True) # open the download link
    file_path = os.path.join(download_folder, file_name)
    with open(file_path, 'wb') as file: # create a new file with write binary mode
        for chunk in response.iter_content(chunk_size=1024):
            if chunk:
                file.write(chunk)

# Can also use '/Reports()' for non-linked reports.
# Can also pass in 'path="<report_path>"' instead of using id numbers,
# e.g. '.../Reports(path="/cool%20reports/my%20report")/HistorySnapshots'
api_url = r'http://<server_name>/reports/api/v2.0/LinkedReports(<item_id>)/HistorySnapshots'
session = requests.session()
session.auth = HttpNegotiateAuth() # uses windows log in
response = session.get(api_url)
hs_snapshot_list = response.json()['value']

for item_dict in hs_snapshot_list:
    download_url = (r'http://<server_name>/ReportServer/Pages/ReportViewer.aspx?<report_path>'
                    + '&rs:Snapshot=' + item_dict['HistoryId']
                    + '&rs:Format=CSV')
    downloadFile(download_url, '<your_file_name>', '<your_download_folder>', session)

SSRS API Resource:
https://app.swaggerhub.com/apis/microsoft-rs/SSRS/2.0#/Reports/GetReportHistorySnapshots

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文