User Defined Functions play an important role in SQL Server. User Defined functions can be used to perform a complex logic, can accept parameters and return data. Many a times we have to write complex logic which cannot be written using a single query. In such scenarios, UDFs play an important role. For example, we can call user defined function in a where clause or use a user defined function in a JOIN [Where UDF returns a result set].
SQL Server supports two types of User Defined Functions as mentioned below –
- Scalar Functions – The function which returns a Scalar/Single value.
- Table Valued Functions – The function which returns a row set of SQL server Table datatype. Table Valued Functions can be written as –
I have preconfigured Northwind database on my SQL Server instance. We will be using the following tables for creating different User Defined Functions –
data:image/s3,"s3://crabby-images/aba19/aba19e1233f9e0719769363b43ae6aa8ddfb3317" alt="tablequeries tablequeries"
data:image/s3,"s3://crabby-images/e3a51/e3a51d66049538b7ac319457397ea1dec910b036" alt="scalar1 scalar1"
The above function returns an integer value. To test this function, we will write some code as shown below –
data:image/s3,"s3://crabby-images/e1252/e1252334271eb50b211ff82474c23ce53c3bfe26" alt="scalartest1 scalartest1"
Let us see another example which will fetch the number of orders processed by an employee for a given year. Write the following function in our query pad –
data:image/s3,"s3://crabby-images/8bab5/8bab50804a3b984ba4cd2869a23e0a566844bb8b" alt="scalar2 scalar2"
We will test this function with different years for an employee as shown below –
data:image/s3,"s3://crabby-images/23c70/23c707ad01b34870ad3d593973394796f2cfeb14" alt="scalartest2 scalartest2"
data:image/s3,"s3://crabby-images/e1b97/e1b976102c0c04c4846e598f313f597973ec11ae" alt="tvf1 tvf1"
To test this example we will use a select statement as shown below –
data:image/s3,"s3://crabby-images/a9fc8/a9fc8a1188e53b398f05b3c6b9aef40120b13df1" alt="tvftest1 tvftest1"
Another example of the Inline Table Valued Function is as shown below –
data:image/s3,"s3://crabby-images/b98ac/b98ac5e8ef41f0207d44214df1d67a218a26488a" alt="tvf2 tvf2"
To test this function, we will use different years as shown below –
data:image/s3,"s3://crabby-images/1c254/1c25461aed278b9cb0680a15e7f3f1fb0dbe3c99" alt="tvftest2 tvftest2"
data:image/s3,"s3://crabby-images/314a9/314a9f9816d9beded2898e065be6230c9b4b423e" alt="clip_image001 clip_image001"
We will now see a Multi-Statement Table Valued Function. This function can be used to perform additional logic within the function. The code is as shown below –
data:image/s3,"s3://crabby-images/09962/09962a219d2d6e9e689acb0d30d017f764d74bea" alt="clip_image003 clip_image003"
To use the Multi-Statement Table Valued function, use this code –
data:image/s3,"s3://crabby-images/e2c76/e2c76b86b428a1e97856edd7793e43c46390dd90" alt="tvfmultistatementtest tvfmultistatementtest"
There are couple of limitations you must consider before creating User Defined Functions. Some of them are as shown below –
Download the source code of this article (Github)
SQL Server supports two types of User Defined Functions as mentioned below –
- Scalar Functions – The function which returns a Scalar/Single value.
- Table Valued Functions – The function which returns a row set of SQL server Table datatype. Table Valued Functions can be written as –
- Inline Table
- Multi-statement Table
I have preconfigured Northwind database on my SQL Server instance. We will be using the following tables for creating different User Defined Functions –
- Customers
- Employees
- Orders
- Order Details
- Products
Scalar Function
We will now create a scalar function, which returns the number of orders placed by a given customer. Write the following code in your query pad –The above function returns an integer value. To test this function, we will write some code as shown below –
Let us see another example which will fetch the number of orders processed by an employee for a given year. Write the following function in our query pad –
We will test this function with different years for an employee as shown below –
Table Valued Functions
Now let’s try an Inline Table valued function. Inline Table valued functions can return a row set using SQL Server Table datatype. You cannot perform addition logic in inline table valued functions. We will fetch the product details purchased by a customer as shown below –To test this example we will use a select statement as shown below –
Another example of the Inline Table Valued Function is as shown below –
To test this function, we will use different years as shown below –
We will now see a Multi-Statement Table Valued Function. This function can be used to perform additional logic within the function. The code is as shown below –
To use the Multi-Statement Table Valued function, use this code –
There are couple of limitations you must consider before creating User Defined Functions. Some of them are as shown below –
- You cannot modify the state of the database using UDFs
- Unlike Stored Procedures, UDF can return only one single result set
- UDF does not support Try-Catch, @ERROR or RAISERROR function
Download the source code of this article (Github)
5 comments:
Awesome article to understand UDF concept with example.
Excellent Sir good job. 1st I see and learn completely about all types of UDFs
Can i get the result of Multi-Statement Table Valued function query result to my mail id , dasari.vinodh@gmail.com
best article for understanding the UDF(User Defined Function)
Very good explanation. Thank you sir.
Post a Comment