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

Code to create log files in C#.Net|Asp.Net

Introduction: In my previous article I have explained about how to create, delete and check whether the directory exists using C#.Net . In this article I am going to explain about  How to create log files in C#.Net. Explanation: Log files are useful to track any runtime errors and exceptions in all the applications. Below code will code will get the Message and Pagename as the input and creates the log file in that date. For that first i have imported below two namespaces.

Dynamically programmatically add contols at run time Asp.Net

Introduction: In my previous article I have explained about What is View State? How to Store and retrieve values from View State . In this article I am going to explain how to add controls programmatically on run time. Explanation: This example adds a text box and button to a Web Forms page at run time. It also dynamically binds an event handler to the button's   Click   event. The handler displays the values of the dynamically generated text box. The controls are added into a   Panel   Web server control, which acts as a placeholder. The controls are separated in the panel with line breaks (HTML <BR> elements), which are added to the panel using the   LiteralControl   control.

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)     { ...