問題描述
Sql server 的float和real等類型會產生科學計數法,比如如果是0.00001的話,會被顯示為1E-5,那要如何才能讓查詢出的結果正常顯示,而不是以奇怪的科學計數法來顯示呢?
分析原因
float 和 real 用於表示浮點數字數據的近似數字數據類型。浮點數據為近似值,並非數據類型范圍內的所有數據都能精確地表示。
因此,解決float科學計數的問題只能靠轉換,比如decimal(12,11)會自動補全到小數點后11位,也可以round(DISCOUNT_RATE,2)四舍五入到百分位。
解決辦法
采用轉換數據類型的方法,先建一個測試表,再插入一條數據:
CREATE TABLE dbo.t_sample ( num float ) INSERT INTO dbo.t_sample VALUES (0.000012345)
轉換SQL:
select replace(rtrim(replace(convert(varchar,cast(num as decimal(10,9))),'0',' ')),' ','0') as num1,round(num,9) as num2 from dbo.t_sample ----------------------------- (No column name) 0.000012346 -----------------------------