Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

Formatting number fields

Posted on 2002-06-04
8
Medium Priority
?
215 Views
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
or
123,456.8
I want define thousand delimiter and number decimal places.
In datetime fields is good function convert, but for decimal or integer not.

Thanks , Petr
0
Comment
Question by:svab
[X]
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
8 Comments
 
LVL 143

Expert Comment

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

CHeers
0
 

Author Comment

by:svab
ID: 7053510
select CONVERT ( money, 1234.67, 1 )
=
1234.6700

Where is my format?
0
 
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)
-----------------
32,234,344.93

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

CHeers

0
Free Backup Tool for VMware and Hyper-V

Restore full virtual machine or individual guest files from 19 common file systems directly from the backup file. Schedule VM backups with PowerShell scripts. Set desired time, lean back and let the script to notify you via email upon completion.  

 

Author Comment

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

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 400 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.
CHeers
0
 

Author Comment

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

Author Comment

by:svab
ID: 7053597
Thank You angellll
by
0
 
LVL 70

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.
0

Featured Post

How to Use the Help Bell

Need to boost the visibility of your question for solutions? Use the Experts Exchange Help Bell to confirm priority levels and contact subject-matter experts for question attention.  Check out this how-to article for more information.

Question has a verified solution.

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

This article explains how to reset the password of the sa account on a Microsoft SQL Server.  The steps in this article work in SQL 2005, 2008, 2008 R2, 2012, 2014 and 2016.
In part one, we reviewed the prerequisites required for installing SQL Server vNext. In this part we will explore how to install Microsoft's SQL Server on Ubuntu 16.04.
Via a live example combined with referencing Books Online, show some of the information that can be extracted from the Catalog Views in SQL Server.
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.

618 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