Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
160 views
in Technique[技术] by (71.8m points)

sql server - How do I retrieve decimals when rounding an average in SQL

Here is my SQL statement

SELECT ROUND(AVG(column_name), 100) 
FROM [database].[dbo].[table]

The answer I retrieve is 3 with a possible range of numbers between 1 - 5 in 908 rows.

I need it to say 3.0 or 3.09. Is this possible?

question from:https://stackoverflow.com/questions/13237477/how-do-i-retrieve-decimals-when-rounding-an-average-in-sql

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

The average will have the same data type as the values, so cast the values:

SELECT ROUND(AVG(CAST(column_name AS FLOAT)), 2) FROM [database].[dbo].[table]

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...