国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解MySQL數據類型int(M)中M的含義

2020-02-23 04:07:48
字體:
來源:轉載
供稿:網友

介紹

MySQL 數據類型中的 integer types 有點奇怪。你可能會見到諸如:int(3)、int(4)、int(8) 之類的 int 數據類型。剛接觸 MySQL 的時候,我還以為 int(3) 占用的存儲空間比 int(4) 要小, int(4) 占用的存儲空間比 int(8) 小。

后來,參看 MySQL 手冊,發現自己理解錯了。

int(M): M indicates the maximum display width for integer types.

在 integer 數據類型中,M 表示最大顯示寬度。

原來,在 int(M) 中,M 的值跟 int(M) 所占多少存儲空間并無任何關系。 int(3)、int(4)、int(8) 在磁盤上都是占用 4 btyes 的存儲空間。說白了,除了顯示給用戶的方式有點不同外,int(M) 跟 int 數據類型是相同的。

另外,int(M) 只有跟 zerofill 結合起來,才能使我們清楚的看到不同之處。

mysql> drop table if exists t;mysql> create table t(id int zerofill);mysql> insert into t(id) values(10);mysql> select * from t;+------------+| id   |+------------+| 0000000010 |+------------+mysql> alter table t change column id id int(3) zerofill;mysql> select * from t;+------+| id |+------+| 010 |+------+mysql>mysql> alter table t change column id id int(4) zerofill;mysql> select * from t;+------+| id |+------+| 0010 |+------+mysql>mysql> insert into t(id) values(1000000);mysql> select * from t;+---------+| id  |+---------+| 0010 || 1000000 |+---------+

從上面的測試可以看出,“(M)”指定了 int 型數值顯示的寬度,如果字段數據類型是 int(4),則:當顯示數值 10 時,在左邊要補上 “00”;當顯示數值 100 是,在左邊要補上“0”;當顯示數值 1000000 時,已經超過了指定寬度“(4)”,因此按原樣輸出。

在使用 MySQL 數據類型中的整數類型(tinyint、smallint、 mediumint、 int/integer、bigint)時,非特殊需求下,在數據類型后加個“(M)”,我想不出有何意義。

下面補充一下數據類型

1、整型

MySQL數據類型 含義(有符號)tinyint(m) 1個字節 范圍(-128~127)smallint(m) 2個字節 范圍(-32768~32767)mediumint(m) 3個字節 范圍(-8388608~8388607)int(m) 4個字節 范圍(-2147483648~2147483647)bigint(m) 8個字節 范圍(+-9.22*10的18次方)

取值范圍如果加了unsigned,則最大值翻倍,如tinyint unsigned的取值范圍為(0~256)。
int(m)里的m是表示SELECT查詢結果集中的顯示寬度,并不影響實際的取值范圍,沒有影響到顯示的寬度,不知道這個m有什么用。

2、浮點型(float和double)

MySQL數據類型 含義float(m,d) 單精度浮點型 8位精度(4字節)  m總個數,d小數位double(m,d) 雙精度浮點型 16位精度(8字節) m總個數,d小數位

設一個字段定義為float(5,3),如果插入一個數123.45678,實際數據庫里存的是123.457,但總個數還以實際為準,即6位。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 合肥市| 平塘县| 建湖县| 竹北市| 明星| 从江县| 西乡县| 东台市| 宕昌县| 阿拉善盟| 德庆县| 和顺县| 灵寿县| 宁海县| 青海省| 青州市| 青阳县| 张北县| 曲靖市| 喀喇沁旗| 泸州市| 高台县| 鹿邑县| 手游| 七台河市| 乐至县| 临泽县| 麻阳| 鹿泉市| 曲松县| 水富县| 甘泉县| 西和县| 新泰市| 保康县| 姜堰市| 横峰县| 分宜县| 漳州市| 卫辉市| 甘孜县|