SQL Server 消除科學計數法


問題描述

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

-----------------------------


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM