So it appears that if you
CAST(field1 as decimal) field1
this will automatically add rounding.
The original is defined as:
field1 type:float length:8 prec:53
I need to cast it to decimal, because I need my Entity Framework layer to generate this field as decimal (instead of double).
Is there a way to cast it as decimal, so that it preserves original precision, and doesn’t round?
I would like to avoid having to declare the precision in the cast, because:
- there are 100’s of fields involved with varying precision, and;
- if the underlying table changes in the future, it could cause unforeseen bugs to emerge, and;
- makes the management more difficult.
Have you tried:
This would return
2.55500000. Is that what you want?UPDATE:
Apparently you can also use SQL_VARIANT_PROPERTY to find the precision and scale of a value. Example:
returns
8|7You may be able to use this in your conversion process…