Formatting number fields

Posted on 2002-06-04
Last Modified: 2008-02-01
Hi, how can I format number field in TSQL ? For example, in database I have field decimal(9,3) with value 123456.789 and I want get
123 456.79
I want define thousand delimiter and number decimal places.
In datetime fields is good function convert, but for decimal or integer not.

Thanks , Petr
Question by:svab
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 7053496
convert to money:
select CONVERT ( money, yourfield, 1 )


Author Comment

ID: 7053510
select CONVERT ( money, 1234.67, 1 )

Where is my format?
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 7053531
sorry, i forgot the second convert:

select convert(varchar(30),convert(money, 32234344.9278),1)

The convert to varchar needs to be from money to use the style property. See the convert topic in the BOL


Is Your DevOps Pipeline Leaking?

Is your CI/CD pipeline a hodge-podge of randomly connected tools? You’ve likely got a tool to fix one problem & then a different tool to fix another, resulting in a cluster of tools with overlapping functionality. Learn how to optimize your pipeline with Gartner's recommendations


Author Comment

ID: 7053560
May I change number decimal places ? I want have 0,1 and 2.
And thousend delimiter is also fix, ",".
LVL 143

Accepted Solution

Guy Hengel [angelIII / a3] earned 100 total points
ID: 7053579
unfortunately, this is not possible.
Of course, you could REPLACE the "," by " ", and eventually truncate the decimal places using

v is the formatted column like above,d the number of decimale:
for d=0:  LEFT( v , CHARINDEX ( '.', v ))
for d=1:  LEFT( v , CHARINDEX ( '.', v )+2)
for d=2:  LEFT( v , CHARINDEX ( '.', v )+3)
d>2 not possible :-)

Now, if you really want better control of formatting, I would rather use the front-end language which typically have much better options to do so. Just an idea.

Author Comment

ID: 7053594
May I change number decimal places ? I want have 0,1 and 2.
And thousend delimiter is also fix, ",".

Author Comment

ID: 7053597
Thank You angellll
LVL 69

Expert Comment

by:Scott Pletcher
ID: 7054944
If you are in SQL 2000, you could write a function which would give you any specific format you wanted.

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
A Stored Procedure in Microsoft SQL Server is a powerful feature that it can be used to execute the Data Manipulation Language (DML) or Data Definition Language (DDL). Depending on business requirements, a single Stored Procedure can return differe…
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function
Using examples as well as descriptions, and references to Books Online, show the documentation available for datatypes, explain the available data types and show how data can be passed into and out of variables.

707 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question