gpt4 book ai didi

sql-server - 使用内联函数在 SSRS 中创建数据集

转载 作者:行者123 更新时间:2023-12-03 00:54:48 24 4
gpt4 key购买 nike

我有一个基于 SQL 的报告,正在将其从 Crystal Reports 迁移到 SSRS。旧方法使用调用存储函数的存储过程。新方法的目的是将所有报告逻辑嵌入到 SSRS 报告中。其背后的原因是存储过程和函数不是目标数据库的一部分。我们不希望有一个只保存一些存储函数和过程的额外数据库。

现在的基本结构是:

select (a bunch of fields)
from (a bunch of joins)
where (conditions)
and specific_value in (select value
from stored_function(inputs)
)

存储的函数会进行一些分隔符处理。我需要在 SSRS 中运行它,而不在数据库中存储任何内容。我可以将存储过程转换为SSRS中的数据集,但我不知道如何处理stored_function。

-----编辑-----这是问题中的代码:

CREATE FUNCTION [dbo].[fn_split] (
@SourceString sql_variant,
@Delimiter nvarchar(10) = N',')
RETURNS @Values TABLE(Position smallint IDENTITY, cValue varchar(2000) , ncValue nvarchar(2000))
AS
BEGIN
DECLARE @NormalString varchar(2000), @NationalString nvarchar(2000),
@NormalDelimiter varchar(10), @NationalDelimiter nvarchar(10),
@IsNationalChar bit, @Position int,
@NormalValue varchar(2000), @NationalValue nvarchar(2000)
SET @Delimiter = COALESCE(@Delimiter, N',')
SET @IsNationalChar = CASE
WHEN SQL_VARIANT_PROPERTY(@SourceString,'BaseType') IN ('char','varchar')
THEN 0
WHEN SQL_VARIANT_PROPERTY(@SourceString,'BaseType') IN ('nchar','nvarchar')
THEN 1
END
IF @IsNationalChar IS NULL RETURN
IF @IsNationalChar = 0
BEGIN
SET @NormalDelimiter = @Delimiter
SET @NormalString = CAST(@SourceString AS varchar(2000))
IF LEFT(@NormalString,LEN(@NormalDelimiter)) = @NormalDelimiter
SET @NormalString = SUBSTRING(@NormalString,LEN(@NormalDelimiter) + 1, 2000)
IF RIGHT(@NormalString,LEN(@NormalDelimiter)) <> @NormalDelimiter
SET @NormalString = @NormalString + @NormalDelimiter
WHILE(1 = 1)
BEGIN
SET @Position = CHARINDEX(@NormalDelimiter,@NormalString) - 1
IF @Position <= 0 BREAK
SET @NormalValue = LEFT(@NormalString,@Position)
SET @NormalString = STUFF(@NormalString,1,@Position + LEN(@NormalDelimiter),'')
INSERT INTO @Values(cValue) VALUES(@NormalValue)
END
END
ELSE IF @IsNationalChar = 1
BEGIN
SET @NationalDelimiter = @Delimiter
SET @NationalString = CAST(@SourceString AS varchar(2000))
IF LEFT(@NationalString,LEN(@NationalDelimiter)) = @NationalDelimiter
SET @NationalString = SUBSTRING(@NationalString,LEN(@NationalDelimiter) + 1,2000)
IF RIGHT(@NationalString,LEN(@NationalDelimiter)) <> @NationalDelimiter
SET @NationalString = @NationalString + @NationalDelimiter
WHILE(1 = 1)
BEGIN
SET @Position = CHARINDEX(@NationalDelimiter,@NationalString) - 1
IF @Position <= 0 BREAK
SET @NationalValue = LEFT(@NationalString,@Position)
SET @NationalString = STUFF(@NationalString,1,@Position + LEN(@NationalDelimiter),'')
INSERT INTO @Values (ncValue) VALUES(@NationalValue)
END
END
RETURN
END

该函数在查询结束时被调用(fn_split)。

select (a bunch of fields)
from (a bunch of joins)
where (conditions)
and specific_value in (select value
from stored_function(input_value)
)

我正在尝试在不使用数据库对象(函数或过程)的情况下重新创建它。我对 SSRS 报告中的代码感到满意。

最佳答案

只是一个想法。您可以使用 2 个数据集:

select (a bunch of fields)
from (a bunch of joins)
where (conditions)
and specific_value in @Algo

select value 
from stored_function(inputs)

关于sql-server - 使用内联函数在 SSRS 中创建数据集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41251230/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com