Hello, all. I couldn't find a forum for T-SQL questions so I hope I am in the right place. I am creating a very simple UDF to calculate a percentage difference:
Create
Function [dbo].[AmtDiffPercentPY](@CY decimal(15), @PY decimal(15))Returns
decimal(15)as
begin
Declare
@difference decimalselect
@difference = (@CY-@PY)/@CYreturn
@differenceEnd
My problem is that when I use float, numeric, or decimal types I get an integer result of zero, when I use money I get a decimal result of 0.00, as if the division is using integer division and not returning the fractional value during division. Any advice
Thanks,
Lisa Morgan

T-SQL Question--right place?
sroughley
lemonsito
unless you don’t specify a precision like decimal(16,2) which means sixteen digits and two decimal places, SQL Server assumes that you want 0 decimal places, which will treat the value as an integer.
HTH, Jens K. Suessmeyer.
---
http://www.sqlserver2005.de
---
A.Carter
Did you try this, this didn't work....
try this:
declare
@p decimal(10,2)select
@p = 8/100select
@pNo decimal