Skip to main content

Sql Query to add comma in price using SQL Server



Introduction:
In my previous article I have explained about How to get selected items text  using Javascript. In this article I am going to explain about how to format numbers in indian(1,23,45,67,890) and US(1,234,567,890) style in SQL.
Explanation:
To format the numbers in indian style I have wrote two sql functions. First function will add the comma(,) after 3 digits from right and the second function will add comma after two two digits from the 3rd digit onward from the right.

Below are the two functions

CREATE FUNCTION [dbo].[fn_FormatWithCommas]    
(   
    -- Add the parameters for the function here   
    @value varchar(50)   
)   
RETURNS varchar(50)   
AS   
BEGIN   
-- Declare the return variable here   
DECLARE @WholeNumber varchar(50) = NULL, @Decimal varchar(10) = '', @CharIndex int = charindex('.', @value)   
   
IF (@CharIndex > 0)
SELECT @WholeNumber = SUBSTRING(@value, 1, @CharIndex-1), @Decimal = SUBSTRING(@value, @CharIndex, LEN(@value))   
ELSE   
   SET @WholeNumber = @value   
   
IF(LEN(@WholeNumber) > 2)   
SET @WholeNumber = dbo.fn_FormatWithCommas2(SUBSTRING(@WholeNumber, 1, LEN(@WholeNumber)-3)) + ',' + RIGHT(@WholeNumber, 3)   
    
-- Return the result of the function   
RETURN @WholeNumber + @Decimal   
   
END 
GO

CREATE FUNCTION [dbo].[fn_FormatWithCommas2]    
(   
    -- Add the parameters for the function here   
    @value varchar(50)   
)   
RETURNS varchar(50)   
AS   
BEGIN   
    -- Declare the return variable here   
DECLARE @WholeNumber varchar(50) = NULL, @Decimal varchar(10) = '', @CharIndex int = charindex('.', @value)   
   
IF (@CharIndex > 0)   
SELECT @WholeNumber = SUBSTRING(@value, 1, @CharIndex-1), @Decimal =     SUBSTRING(@value, @CharIndex, LEN(@value))   
ELSE   
    SET @WholeNumber = @value   
   
IF(LEN(@WholeNumber) > 2)   
SET @WholeNumber = dbo.fn_FormatWithCommas2(SUBSTRING(@WholeNumber, 1, LEN(@WholeNumber)-2)) + ',' + RIGHT(@WholeNumber, 2)   

-- Return the result of the function   
RETURN @WholeNumber + @Decimal   
   
END

Below is the sample usage of the code.
DECLARE @price INT
SET @price=1234567890
SELECT dbo.fn_FormatWithCommas(1234567890)

Below is the code to format numbers in US style
SELECT CONVERT(varchar, CAST(987654321 AS money), 1)

Do you like this article? Help us to improve. Please post your comments below.

Comments

Popular posts from this blog

Sort Dictionary Based On Value In Asp.Net And C#.Net | Convert Dictionary into KeyValuePair or KeyValuePair into Dictionary.

In this tutorial i am going to explain about how to sort dictionary object based on value in asp.net and C#.Net or convert unsorted dictionary to sorted dictionary object in C#.Net and VB.Net or Convert Dictionary into KeyValuePair or KeyValuePair into Dictionary.

Code To Convert rupees(numbers) into words using C#.Net

Introduction: In my previous article I have explained about how to validate emailid using javascript . In this article I am going to explain about code used to convert rupees(numbers) into words using C#.Net . Explanation: For explanation purpose I have a page. It has a textbox to input the numbers. And when you click on the convert to words button then it will convert the input numbers into words and shows it in the below label. Below is the C# code used to do this functionality. public static string NumbersToWords( int inputNumber) {     int inputNo = inputNumber;     if (inputNo == 0)         return "Zero" ;     int [] numbers = new int [4];     int first = 0;     int u, h, t;     System.Text. StringBuilder sb = new System.Text. StringBuilder ();     if (inputNo < 0)     { ...

C# code to send mail using smtp from gmail,yahoo mail and live mail

Introduction: In my previous article I have explained about   How to bind/Unbind events in jQuery . In this article I am going to explain about how to send mail from ASP.Net using gmail,yahoomail and live mail credentials. Explanation: First Include the below namespaces in your code behind file. using System; using System.Net; using System.Net.Mail;