由於業務需要,把本來的varchar2轉換成了number(22,2),其中有一個欄位儲存的是0.xx型別的資料。問題來了,今天再次查詢發現資料庫中儲存的是0.01,但是查詢結果是.01,開始以為是程式碼問題,排查後發現問題在於bean中是string,在查詢對映轉換中把前面的0省略掉了(度娘說是儲存時為了節省空間,可是表裡會什麼沒有省略0呢?查詢做char轉換才省略?)
網上搜到了幾種解決辦法:
1)select to_char(rate) from mytest;
data:image/s3,"s3://crabby-images/d1055/d1055efeb4377302e99adb7203a8d8bc30d5c83e" alt="記錄oracle中查詢資料0.xx結果為.xx的解決辦法"
data:image/s3,"s3://crabby-images/dd13f/dd13f151d5d594d3ac69a3ae9edd20a33d76e39d" alt="記錄oracle中查詢資料0.xx結果為.xx的解決辦法"
2)select case when rate like '.%' then '0'||rate else to_char(rate) end from mytest;
data:image/s3,"s3://crabby-images/00cde/00cded92467e0f7e9ab0196fb621d0263da3d447" alt="記錄oracle中查詢資料0.xx結果為.xx的解決辦法"
data:image/s3,"s3://crabby-images/e16ed/e16edc429f21da9d16183f744ab88961c3ee5aeb" alt="記錄oracle中查詢資料0.xx結果為.xx的解決辦法"
4) select to_char(rate,'fm9999990.9999') from mytest;
data:image/s3,"s3://crabby-images/fe199/fe1993f18f83bc59c1bd0685417e4af63ebf9bd7" alt="記錄oracle中查詢資料0.xx結果為.xx的解決辦法"
猜想:前面說的為什麼資料庫中顯示的是0.22,我覺得實際儲存應該 還是0.22,只是在查詢中做了隱是式轉換,程式碼底層把number類轉換成了string.通過substring函式擷取第一位是點不是0,可能是在subtrings時就已經先to_char把number轉了型別。。