亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL數據類型DECIMAL使用心得

發布時間:2020-06-01 16:14:44 來源:網絡 閱讀:2284 作者:三月 欄目:MySQL數據庫

本篇文章給大家主要講的是關于MySQL數據類型DECIMAL使用心得的內容,感興趣的話就一起來看看這篇文章吧,相信看完MySQL數據類型DECIMAL使用心得對大家多少有點參考價值吧。

1.DECIMAL類型簡介

DECIMAL從MySQL 5.1引入,列的聲明語法是DECIMAL(M,D)。NUMERIC與DECIMAL同義,如果字段類型定義為NUMERIC,則將自動轉成DECIMAL。

對于聲明語法DECIMAL(M,D),自變量的值范圍如下:

  • M是最大位數(精度),范圍是1到65。可不指定,默認值是10。
  • D是小數點右邊的位數(小數位)。范圍是0到30,并且不能大于M,可不指定,默認值是0。

例如字段 salary DECIMAL(5,2),能夠存儲具有五位數字和兩位小數的任何值,因此可以存儲在salary列中的值的范圍是從-999.99到999.99。

2.DECIMAL使用實戰

下面我們將創建測試表來驗證DECIMAL字段類型的使用:

# 創建具有DECIMAL字段的表 驗證decimal默認是decimal(10,0)
mysql> create table decimal_tb (col1 decimal,col2 decimal(5,2));
Query OK, 0 rows affected (0.04 sec)

mysql> show create table decimal_tb\G
*************************** 1. row ***************************
       Table: decimal_tb
Create Table: CREATE TABLE `decimal_tb` (
  `col1` decimal(10,0) DEFAULT NULL,
  `col2` decimal(5,2) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

# 插入數據測試 
# 結論:超出存儲范圍會報錯,小數位不足會自動補0,首位數字為0自動忽略,小數位超出會截斷 并按四舍五入處理。
mysql> insert into decimal_tb (col1,col2) values (100,100);
Query OK, 1 row affected (0.05 sec)

mysql> insert into decimal_tb (col2) values (1.23);
Query OK, 1 row affected (0.01 sec)

mysql> insert into decimal_tb (col2) values (10.2);
Query OK, 1 row affected (0.01 sec)

mysql> insert into decimal_tb (col2) values (09.9);
Query OK, 1 row affected (0.01 sec)

mysql> select * from decimal_tb;
+------+--------+
| col1 | col2   |
+------+--------+
|  100 | 100.00 |
| NULL |   1.23 |
| NULL |  10.20 |
| NULL |   9.90 |
+------+--------+
4 rows in set (0.00 sec)

mysql> insert into decimal_tb (col2) values (9999);
ERROR 1264 (22003): Out of range value for column 'col2' at row 1

mysql> insert into decimal_tb (col2) values (12.233); 
Query OK, 1 row affected, 1 warning (0.01 sec)

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

mysql> insert into decimal_tb (col2) values (12.2300);
Query OK, 1 row affected (0.01 sec)

# 變量范圍測試
# 結論:M范圍是1到65,D范圍是0到30,且D不大于M
mysql> alter table decimal_tb add column col3 decimal(6,6);
Query OK, 0 rows affected (0.12 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col4 decimal(6,7); 
ERROR 1427 (42000): For float(M,D), double(M,D) or decimal(M,D), M must be >= D (column 'col4').

mysql> alter table decimal_tb add column col4 decimal(65,2);
Query OK, 0 rows affected (0.11 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col4 decimal(66,2);
ERROR 1426 (42000): Too-big precision 66 specified for 'col4'. Maximum is 65.

mysql> alter table decimal_tb add column col5 decimal(60,30); 
Query OK, 0 rows affected (0.13 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col6 decimal(60,31);
ERROR 1425 (42000): Too big scale 31 specified for column 'col6'. Maximum is 30.
3.DECIMAL使用總結

上面的內容從實戰出發,介紹了DECIMAL類型的使用方法及注意事項,你可能也知道float、double這些浮點數類型,這兩個同樣可以存儲小數,但這里不過多介紹,只是提醒大家float、double類型無法確保精度,很容易產生誤差,特別是在求和計算的時候,所有當存儲小數,特別是涉及金額時推薦使用DECIMAL類型。這里總結下使用DECIMAL應該注意的事項:

  • DECIMAL(M,D)中,M范圍是1到65,D范圍是0到30。
  • M默認為10,D默認為0,D不大于M。
  • DECIMAL(5,2)可存儲范圍是從-999.99到999.99,超出存儲范圍會報錯。
  • 存儲數值時,小數位不足會自動補0,首位數字為0自動忽略。
  • 小數位超出會截斷,產生告警,并按四舍五入處理。
  • 使用DECIMAL字段時,建議M,D參數手動指定,并按需分配。

以上關于MySQL數據類型DECIMAL使用心得詳細內容,對大家有幫助嗎?如果想要了解更多相關,可以繼續關注我們的行業資訊板塊。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

含山县| 洛川县| 赞皇县| 镇巴县| 绍兴市| 柏乡县| 贵溪市| 政和县| 大宁县| 新乡县| 乾安县| 丽江市| 高碑店市| 庆云县| 巍山| 灵台县| 西林县| 丹巴县| 布尔津县| 米林县| 大安市| 连山| 沁源县| 修武县| 大关县| 菏泽市| 深圳市| 忻城县| 漾濞| 环江| 修水县| 休宁县| 遂川县| 山东省| 元氏县| 高要市| 盐城市| 阿坝| 水城县| 工布江达县| 晋中市|