婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL中Decimal類型和Float Double的區別(詳解)

MySQL中Decimal類型和Float Double的區別(詳解)

熱門標簽:遂寧400電話申請 趙縣地圖標注 地圖標注直通車 永州智能外呼系統 電銷機器人市場價 dq8 全地圖標注 南寧智能電銷機器人價格 哈爾濱云外呼系統運營商 邯鄲400電話注冊辦理

MySQL中存在float,double等非標準數據類型,也有decimal這種標準數據類型。

其區別在于,float,double等非標準類型,在DB中保存的是近似值,而Decimal則以字符串的形式保存數值。
float,double類型是可以存浮點數(即小數類型),但是float有個壞處,當你給定的數據是整數的時候,那么它就以整數給你處理。這樣我們在存取貨幣值的時候自然遇到問題,我的default值為:0.00而實際存儲是0,同樣我存取貨幣為12.00,實際存儲是12。

幸好mysql提供了兩個數據類型:decimal,這種數據類型可以輕松解決上面的問題:decimal類型被 MySQL 以同樣的類型實現,這在 SQL92 標準中是允許的。他們用于保存對準確精度有重要要求的值,例如與金錢有關的數據。

數據定義

float(M,S) M為全長,S為小數點后長度。對于不精準的例子,網絡上很多,Copy如下:

mysql> create table t1(c1 float(10,2), c3decimal(10,2));

Query OK, 0 rows affected (0.02 sec)

mysql> insert into t1 values(9876543.21, 9876543.12);

Query OK, 1 row affected (0.00 sec)

mysql> select * from t1;

+----------------+-----------------+

| c1 | c3 |

+----------------+-----------------+

| 9876543.00 | 9876543.12 |

+----------------+------------------+

2 rows in set (0.00 sec)

再舉例: DECIMAL(5,2)

mysql> create table t1(id1 float(5,2) default null,id2 double(5,2) default null,
id3 decimal(5,2) default null );

mysql> insert into t1 values(1.2345,1.2345,1.2345);
Query OK, 1 row affected, 1 warning (0.04 sec)

mysql> show warnings;
+-------+------+------------------------------------------+
| Level | Code | Message |
+-------+------+------------------------------------------+
| Note | 1265 | Data truncated for column 'id3' at row 1 |
+-------+------+------------------------------------------+
1 row in set (0.00 sec)

1.2345 --- 小數點后最多2位,所以保存可以,自動四舍五入數據截斷,但會報waning

12.34 --- OK

1234.5 --- 因為小數部分未滿2位,要補0.所以保存應該1234.50。所以整個位數超出了5,保存報錯。

1.2 --- 小數未滿部分補0。按照1.20保存。

默認狀態比較

浮點數如果不寫經度和標度,會按照實際精度值保存,如果有精度和標度,則會自動將四舍五入后的結果插入,系統不會報錯;定點數如果不寫精度和標度,則按照默認值decimal(10,0) 來操作,如果數據超過了精度和標度值,系統會報錯。

以上這篇MySQL中Decimal類型和Float Double的區別(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • mysql中decimal數據類型小數位填充問題詳解
  • MySQL decimal unsigned更新負數轉化為0
  • 淺談MySQL中float、double、decimal三個浮點類型的區別與總結
  • 深入分析MySQL數據類型 DECIMAL
  • MySQL中decimal類型用法的簡單介紹
  • 詳解MySQL數據類型DECIMAL(N,M)中N和M分別表示的含義
  • MySQL數據類型中DECIMAL的用法實例詳解
  • MySQL數據類型DECIMAL用法詳解

標簽:上海 南寧 阿里 中衛 定西 浙江 鄂州 張家界

巨人網絡通訊聲明:本文標題《MySQL中Decimal類型和Float Double的區別(詳解)》,本文關鍵詞  MySQL,中,Decimal,類型,和,Float,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL中Decimal類型和Float Double的區別(詳解)》相關的同類信息!
  • 本頁收集關于MySQL中Decimal類型和Float Double的區別(詳解)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 息烽县| 福安市| 襄垣县| 建阳市| 石台县| 政和县| 永康市| 获嘉县| 杭州市| 雷山县| 射阳县| 新乡县| 乡宁县| 泽普县| 永仁县| 闸北区| 夏津县| 化德县| 盘山县| 江西省| 济源市| 二手房| 大港区| 林口县| 隆德县| 钟祥市| 田东县| 西乌珠穆沁旗| 文安县| 镇安县| 大庆市| 大兴区| 和平县| 马尔康县| 田阳县| 罗定市| 聂拉木县| 博白县| 嘉祥县| 邹平县| 景宁|