Table-Valued Functions
Learn how to return a table as a function result.
Apart from scalar values, functions can return tables. Such functions are called table-valued functions. They can be of two types:
- Inline table-valued functions.
- Multi-statement table-valued functions.
Inline table-valued functions
Inline table-valued functions are used to return the result of a SELECT
statement they encapsulate. The declaration differs from scalar-valued function declaration:
CREATE FUNCTION dbo.InlineTableValuedFunction(@ParameterName ParameterType, ...)
RETURNS TABLE
AS
RETURN
[SELECT query];
We must note two differences from the scalar-valued function declaration:
- There are no
BEGIN
andEND
keywords to mark the function body. - The return type is
TABLE
.
Usage
Inline table-valued functions are used differently than scalar-valued functions. While we use SELECT
to see the result of a scalar-valued function, we must select from a table-valued function:
SELECT * FROM dbo.TableValuedFunction('Some parameter')
Example
To gain hands-on experience, let’s try an example. Let’s consider a situation where we have a table called FinalExamScores
, which stores the final exam scores of seniors in an anonymous manner for each year.
Get hands-on with 1300+ tech skills courses.