Skip to main content

Functions - SQL Server

 Functions

In SQL Server, a function is a pre-written piece of code that performs a specific task and returns a value. Functions can be used to encapsulate complex calculations, to improve performance by reducing network traffic, and to enforce security by restricting direct access to database tables.

There are two types of functions in SQL Server:

1.     Scalar Functions: These functions return a single value based on input parameters. Examples include LEN, which returns the length of a string, and SUM, which returns the sum of a set of values.

2.     Table-Valued Functions: These functions return a table or a set of rows based on input parameters. Examples include fnSplit, which splits a string into rows based on a delimiter, and fnGetSalesByMonth, which returns sales data grouped by month.

To create a function in SQL Server, you can use the CREATE FUNCTION statement. Here's an example of creating a scalar function:

CREATE FUNCTION GetTotalOrders

(

    @CustomerID int

)

RETURNS int

AS

BEGIN

    DECLARE @TotalOrders int;

    SELECT @TotalOrders = COUNT(*) FROM Orders WHERE CustomerID = @CustomerID;

    RETURN @TotalOrders;

END

In this example, we're creating a scalar function called GetTotalOrders that takes an input parameter called @CustomerID and returns an integer value. The function uses a SELECT statement to count the number of orders for the specified customer ID and stores the result in a variable called @TotalOrders. Finally, the function returns the value of @TotalOrders.

Here's an example of creating a table-valued function:

CREATE FUNCTION fnGetSalesByMonth

(

    @Year int

)

RETURNS TABLE

AS

RETURN

(

    SELECT MONTH(OrderDate) AS Month, SUM(TotalAmount) AS TotalSales

    FROM Orders

    WHERE YEAR(OrderDate) = @Year

    GROUP BY MONTH(OrderDate)

)

 

In this example, we're creating a table-valued function called fnGetSalesByMonth that takes an input parameter called @Year and returns a table with two columns: Month and TotalSales. The function uses a SELECT statement to retrieve sales data for the specified year, grouping the data by month and calculating the total sales for each month.

Once you've created the function, you can call it like any other function. For example:

SELECT dbo.GetTotalOrders(12345);

 In this example, we're calling the GetTotalOrders function with an input parameter of 12345. The function will return the total number of orders for the

specified customer ID.

Reference :

            https://learn.microsoft.com/en-us/sql/t-sql/statements/create-function-transact-sql?view=sql-server-ver16

Comments

Popular posts from this blog

SFTP Integration in SSIS package Using WinSCP DLL

  In this blog, I am planning to write about SSIS SFTP Task details and reference sites, upload and download the files from SFTP server using SSIS package with help of the winscp library. Steps to configure the winscp DLL and Download Files 1.        Please download the DLL and required files from below path https://winscp.net/eng/downloads.php#additional 2.        Once Downloaded, use the below comments to add in Local GAC "Path to the gacutil exe \gacutil.exe" /i WinSCPnet.dll 3.        Please use the below URL as guide to implement the SSIS script task to download the files from SFTP using winscp as library https://winscp.net/eng/docs/library_ssis 4.        I am just briefing the steps based on the above URL what we can try in SSIS package. 5.        Please create the below variables in SSIS package which we need ...

Geography Data Type – SQL Server

     Geography data type in SQL Server is a useful tool for storing and manipulating geographic data. It provides a set of functions and tools for working with geographical data, such as points, lines, and polygons. In this blog, we will explore the Geography data type in SQL Server with examples. Introduction to Geography data type Geography data type is a built-in data type in SQL Server that is designed to support the storage, manipulation, and analysis of geographic data. It is based on the Open Geospatial Consortium (OGC) Simple Feature Access specification, which provides a standard way to represent geographic data in a database. The Geography data type in SQL Server stores data in a geographic coordinate system, allowing you to represent points on the surface of the earth using longitude and latitude coordinates. You can also represent lines and polygons by defining a series of points that define the shape of the line or polygon. Creating a Geography data t...

XML data type Functions – SQL Server

 The XML data type in MSSQL Server is a powerful tool for handling and manipulating XML data within a relational database system. In addition to storing XML data as a column in a table, SQL Server provides a number of XML functions and methods that allow for easy parsing, querying, and transformation of XML data. In this blog post, we will cover all XML data type methods available in MSSQL Server. value() Method: The value() method is used to extract a single value from an XML instance. This method accepts an XQuery expression as a parameter, which is used to identify the value to be extracted. The syntax of the value() method is as follows: xml . value ( XQuery expression , Data type ) For example, the following query extracts the value of the 'name' element from an XML column called 'MyXMLColumn': SELECT MyXMLColumn . value ( '(/Root/Person/Name)[1]' , 'varchar(50)' ) AS Name FROM MyTable   query() Method: The query() method i...