我有一个这样的数据表:
Group ID M0 M1 ... M20
------------------------------------
1 1 10 -2 ... 54
1 2 -8 10 ... -20
2 6 -10 12 ... 0
2 4 45 52 ... 0
2 5 12 102 ... 0
我按组对我的数据进行分组,如下所示:
SELECT Group
, round(sum(M0+M1+M2+...+M20)/count(ID),2) as profit
, round(sum(M0),2) as M0
, round(sum(M1),2) as M1
, ...
, round(sum(M20),2) as M20
FROM
data_table
GROUP BY
Group
我需要添加的是基于 M0 到 M20 列的 IRR。
我找到了一个看起来像这样的 IRR 函数:
CREATE FUNCTION [dbo].[ufn_IRR]
(
@strIDs VARCHAR(8000),
@guess DECIMAL(30,10)
)
RETURNS DECIMAL(30, 10)
AS
BEGIN
DECLARE @t_IDs TABLE (
id INT IDENTITY(0, 1),
value DECIMAL(30, 10)
)
DECLARE @strID VARCHAR(12),@sepPos INT,@NPV DECIMAL(30, 10)
SET @strIDs = COALESCE(@strIDs + ',', '')
SET @sepPos = CHARINDEX(',', @strIDs)
WHILE @sepPos > 0
BEGIN
SET @strID = LEFT(@strIDs, @sepPos - 1)
INSERT INTO @t_IDs ( value ) SELECT ( CAST(@strID AS DECIMAL(20, 10)) ) WHERE ISNUMERIC(@strID) = 1
SET @strIDs = RIGHT(@strIDs, DATALENGTH(@strIDs) - @sepPos)
SET @sepPos = CHARINDEX(',', @strIDs)
END
SET @guess = CASE WHEN ISNULL(@guess, 0) <= 0 THEN 0.00001 ELSE @guess END
SELECT @NPV = SUM(value / POWER(1 + @guess, id)) FROM @t_IDs
WHILE @NPV > 0
BEGIN
SET @guess = @guess + 0.00001
SELECT @NPV = SUM(value / POWER(1 + @guess, id)) FROM @t_IDs
END
RETURN @guess
END
示例用法如下所示:
SELECT dbo.ufn_IRR('-4000,1200,1410,1875,1050',0.00001)
但就我而言,我想避免从我的列中创建字符串,如下所示:
SELECT dbo.ufn_IRR(
cast(round(sum([M0]), 2) AS NVARCHAR)+','
+cast(round(sum([M1]), 2) AS NVARCHAR)+','
+cast(round(sum([M2]), 2) AS NVARCHAR)+','
+cast(round(sum([M3]), 2) AS NVARCHAR)+','
+cast(round(sum([M4]), 2) AS NVARCHAR)+','
+...+','
+cast(round(sum([M20]), 2) AS NVARCHAR)
,0.00001)
我认为首先创建一个字符串然后在函数内部将其切入表格是没有意义的。
我想修改 IRR 函数,这样我就可以传递我的列,但我不知道该怎么做:/