国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

詳解MySQL數(shù)據(jù)類(lèi)型int(M)中M的含義

Original 2017-01-09 13:03:23 369
abstract:介紹MySQL 數(shù)據(jù)類(lèi)型中的 integer types 有點(diǎn)奇怪。你可能會(huì)見(jiàn)到諸如:int(3)、int(4)、int(8) 之類(lèi)的 int 數(shù)據(jù)類(lèi)型。剛接觸 MySQL 的時(shí)候,我還以為 int(3) 占用的存儲(chǔ)空間比 int(4) 要小, int(4) 占用的存儲(chǔ)空間比 int(8) 小。 后來(lái),參看 MySQL 手冊(cè),發(fā)現(xiàn)自己理解錯(cuò)了。int(M): M in

介紹

MySQL 數(shù)據(jù)類(lèi)型中的 integer types 有點(diǎn)奇怪。你可能會(huì)見(jiàn)到諸如:int(3)、int(4)、int(8) 之類(lèi)的 int 數(shù)據(jù)類(lèi)型。剛接觸 MySQL 的時(shí)候,我還以為 int(3) 占用的存儲(chǔ)空間比 int(4) 要小, int(4) 占用的存儲(chǔ)空間比 int(8) 小。 

后來(lái),參看 MySQL 手冊(cè),發(fā)現(xiàn)自己理解錯(cuò)了。

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

在 integer 數(shù)據(jù)類(lèi)型中,M 表示最大顯示寬度。

原來(lái),在 int(M) 中,M 的值跟 int(M) 所占多少存儲(chǔ)空間并無(wú)任何關(guān)系。 int(3)、int(4)、int(8) 在磁盤(pán)上都是占用 4 btyes 的存儲(chǔ)空間。說(shuō)白了,除了顯示給用戶(hù)的方式有點(diǎn)不同外,int(M) 跟 int 數(shù)據(jù)類(lèi)型是相同的。 

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

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 |
+---------+

   

從上面的測(cè)試可以看出,“(M)”指定了 int 型數(shù)值顯示的寬度,如果字段數(shù)據(jù)類(lèi)型是 int(4),則:當(dāng)顯示數(shù)值 10 時(shí),在左邊要補(bǔ)上 “00”;當(dāng)顯示數(shù)值 100 是,在左邊要補(bǔ)上“0”;當(dāng)顯示數(shù)值 1000000 時(shí),已經(jīng)超過(guò)了指定寬度“(4)”,因此按原樣輸出。 

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

下面補(bǔ)充一下數(shù)據(jù)類(lèi)型 

1、整型

MySQL數(shù)據(jù)類(lèi)型 含義(有符號(hào))
tinyint(m) 1個(gè)字節(jié) 范圍(-128~127)
smallint(m) 2個(gè)字節(jié) 范圍(-32768~32767)
mediumint(m) 3個(gè)字節(jié) 范圍(-8388608~8388607)
int(m) 4個(gè)字節(jié) 范圍(-2147483648~2147483647)
bigint(m) 8個(gè)字節(jié) 范圍(+-9.22*10的18次方)

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

2、浮點(diǎn)型(float和double)

MySQL數(shù)據(jù)類(lèi)型 含義
float(m,d) 單精度浮點(diǎn)型 8位精度(4字節(jié))  m總個(gè)數(shù),d小數(shù)位
double(m,d) 雙精度浮點(diǎn)型 16位精度(8字節(jié)) m總個(gè)數(shù),d小數(shù)位

設(shè)一個(gè)字段定義為float(5,3),如果插入一個(gè)數(shù)123.45678,實(shí)際數(shù)據(jù)庫(kù)里存的是123.457,但總個(gè)數(shù)還以實(shí)際為準(zhǔn),即6位。 

3、定點(diǎn)數(shù) 

浮點(diǎn)型在數(shù)據(jù)庫(kù)中存放的是近似值,而定點(diǎn)類(lèi)型在數(shù)據(jù)庫(kù)中存放的是精確值。

decimal(m,d) 參數(shù)m<65 是總個(gè)數(shù),d<30且 d<m 是小數(shù)位。

4、字符串(char,varchar,_text)

MySQL數(shù)據(jù)類(lèi)型 含義
char(n)  固定長(zhǎng)度,最多255個(gè)字符
varchar(n) 可變長(zhǎng)度,最多65535個(gè)字符
tinytext 可變長(zhǎng)度,最多255個(gè)字符
text  可變長(zhǎng)度,最多65535個(gè)字符
mediumtext 可變長(zhǎng)度,最多2的24次方-1個(gè)字符
longtext 可變長(zhǎng)度,最多2的32次方-1個(gè)字符

5、日期和時(shí)間數(shù)據(jù)類(lèi)型

MySQL數(shù)據(jù)類(lèi)型 含義
date  3字節(jié),日期,格式:2014-09-18
time  3字節(jié),時(shí)間,格式:08:42:30
datetime 8字節(jié),日期時(shí)間,格式:2014-09-18 08:42:30
timestamp 4字節(jié),自動(dòng)存儲(chǔ)記錄修改的時(shí)間
year  1字節(jié),年份

更多關(guān)于詳解MySQL數(shù)據(jù)類(lèi)型int(M)中M的含義請(qǐng)關(guān)注PHP中文網(wǎng)(m.miracleart.cn)其他文章!   


Release Notes

Popular Entries