• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 174
  • Last Modified:

decimel help

Hello All,

I have a table where a column is gets updated by the division of a column from another table by any denominator value between 3 and 9. So it could be metric column / 3  or metriColumn/4 , etc.

Now in terms of the maximum of decimals for highest accuracy – s – what should be used? Wen creating that table to store the division result column – I am using –
CREATE TABLE [dbo].[myTable](
            [divisionResults] [decimal](18, 4) NULL
) ON [PRIMARY]

 I want to use storage type that allows me the maximum decimal places after zero but also doesn’t compromise the query efficiency or speed or that I am “overkilling” it
0
Rayne
Asked:
Rayne
  • 4
  • 4
  • 3
  • +1
3 Solutions
 
Vitor MontalvãoMSSQL Senior EngineerCommented:
You can see the precision for decimal data type here and as far as I know the precision doesn't impact the query performance.
0
 
Aaron TomoskyTechnology ConsultantCommented:
One additional thing to rember is when you do math in sql with an int and a decimal, depending on the specific order of the numbers (decimal/int , int/decimal) you can get the result as an int when you want a decimal.
http://www.experts-exchange.com/Database/MS-SQL-Server/Q_24432624.html

I prefer to explicitly cast my int as a decimal but there are lots of ways.
Decimal / cast (int as decimal(18,4)
0
 
Vitor MontalvãoMSSQL Senior EngineerCommented:
depending on the specific order of the numbers (decimal/int , int/decimal) you can get the result as an int when you want a decimal.
That's not true. In both case the result will be always a decimal.
Only if the operation is int/int that the result will be int.
0
The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

 
Aaron TomoskyTechnology ConsultantCommented:
whoops, that's right. I've just gotten in the habit of casting everything to avoid odd issues.
http://improve.dk/tricky-sql-server-decimal-math/
0
 
RayneAuthor Commented:
[myResults] [decimal](18, 4) NULL
so whats the max number of decimel that i can use? instead of 4 like up till 12 or more?
0
 
Aaron TomoskyTechnology ConsultantCommented:
0
 
RayneAuthor Commented:
please suggest a valid one - this is leading to arithmetic overflow
0
 
RayneAuthor Commented:
all eexperts - please suggest whats your best practise of using which one decimel ? i dont want my program to crash
0
 
Aaron TomoskyTechnology ConsultantCommented:
in your example (18,4) that means 18 total digits, 4 to the right of the decimal point. Unless you care about more digits to the right of the decimal point, that should be fine for numbers up to 99 trillion (99,999,999,999,999.9999)
0
 
Vitor MontalvãoMSSQL Senior EngineerCommented:
all eexperts - please suggest whats your best practise of using which one decimel ? i dont want my program to crash
There's no best practice but client/business demands. What's the precision that they need? You just need this answer to set the best data type.
0
 
DcpKingCommented:
As Aaron and Vitor say, you select your total number of digits and your number of decimal places within that, For example, if you're working with something like national expenditures then 18,4 might be good. OTOH, for chemical analyses something like 18,12 might be more appropriate.

As others have noted, use a decimal value as your denominator, if for no other reason than to make everything clear to subsequent readers of your code. If you are working with large amounts of data then every calculation will include an implicit conversion if you leave it as an integer. While this probably won't be as expensive as dividing by '4' (as a varchar or char) it will still incur some extra overhead.

hth

Mike
0
 
RayneAuthor Commented:
Thank you Sire Mike and the other Gurus, thank you
0
 
DcpKingCommented:
"Sire Mike" !! LOL!!!

I appreciate the thought.  --  Mike
0

Featured Post

Never miss a deadline with monday.com

The revolutionary project management tool is here!   Plan visually with a single glance and make sure your projects get done.

  • 4
  • 4
  • 3
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now