Windowed functions cannot be used in the context of another windowed function or aggregate.

Error Message:
Msg 4109, Level 15, State 1, Line 1
Windowed functions cannot be used in the context of another windowed function or aggregate.

Severity level:
15.

Description:
This error message appears when you try to use a windowed function within another function or aggregate function.

Consequences:
The T-SQL statement can be parsed, but causes the error at runtime.

Resolution:
Errors of the Severity Level 15 are generated by the user and can be fixed by the SQL Server user. The statement cannot be executed this way. You cannot use these function within other functions or aggregate functions.

Versions:
This error message was introduced with SQL Server 2005.

Example(s):
USE tempdb;
GO
IF OBJECT_ID(‘tempdb..#t’) > 0
 DROP TABLE #t
GO
CREATE TABLE #t
(
 id INT
)
INSERT INTO #t SELECT 10
GO
SELECT SUM(ROW_NUMBER() OVER(ORDER BY ID)) AS rid, id
  FROM #t
 GROUP BY id

Remarks:
In the above example we try to use the ROW_NUMBER() function within the SUM() aggregate function. This raises the error.

]]>

Leave a comment

Your email address will not be published.