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

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

MySQL數(shù)據(jù)類型 int(M)什么意思

2024-07-24 12:37:52
字體:
供稿:網(wǎng)友

int(M)我們先來拆分,int是代表整型數(shù)據(jù)那么中間的M應(yīng)該是代表多少位了,后來查mysql手冊也得知了我的理解是正確的,下面我來舉例說明.

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

后來,參看 MySQL 手冊,發(fā)現(xiàn)自己理解錯了,代碼如下:

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

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

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

另外,int(M) 只有跟 zerofill 結(jié)合起來,才能使我們清楚的看到不同之處,代碼如下:

  1. mysql> drop table if exists t; 
  2. mysql> create table t(id int zerofill); 
  3. mysql> insert into t(id) values(10); 
  4. mysql> select * from t; 
  5. +------------+ 
  6. | id         | 
  7. +------------+ 
  8. | 0000000010 | 
  9. +------------+ 
  10. mysql> alter table t change column id id int(3) zerofill; 
  11. mysql> select * from t; 
  12. +------+ 
  13. | id   | 
  14. +------+ 
  15. |  010 | 
  16. +------+ 
  17. mysql> 
  18. mysql> alter table t change column id id int(4) zerofill; 
  19. mysql> select * from t; 
  20. +------+ 
  21. | id   | 
  22. +------+ 
  23. | 0010 | 
  24. +------+ 
  25. mysql> 
  26. mysql> insert into t(id) values(1000000); 
  27. mysql> select * from t;  --Vevb.com 
  28. +---------+ 
  29. | id      | 
  30. +---------+ 
  31. |    0010 | 
  32. | 1000000 | 
  33. +---------+ 

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

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

下面補充一下數(shù)據(jù)類型:

1、整型

MySQL數(shù)據(jù)類型 含義(有符號)

tinyint(m) 1個字節(jié)  范圍(-128~127)

smallint(m) 2個字節(jié)  范圍(-32768~32767)

mediumint(m) 3個字節(jié)  范圍(-8388608~8388607)

int(m) 4個字節(jié)  范圍(-2147483648~2147483647)

bigint(m) 8個字節(jié)  范圍(+-9.22*10的18次方)

取值范圍如果加了unsigned,則最大值翻倍,如tinyint unsigned的取值范圍為(0~256).

int(m)里的m是表示SELECT查詢結(jié)果集中的顯示寬度,并不影響實際的取值范圍,沒有影響到顯示的寬度,不知道這個m有什么用.

2、浮點型(float和double)

MySQL數(shù)據(jù)類型 含義

float(m,d) 單精度浮點型    8位精度(4字節(jié))     m總個數(shù),d小數(shù)位

double(m,d) 雙精度浮點型    16位精度(8字節(jié))    m總個數(shù),d小數(shù)位

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

3、定點數(shù)

浮點型在數(shù)據(jù)庫中存放的是近似值,而定點類型在數(shù)據(jù)庫中存放的是精確值.

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

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

MySQL數(shù)據(jù)類型 含義

char(n) 固定長度,最多255個字符

varchar(n) 固定長度,最多65535個字符

tinytext 可變長度,最多255個字符

text 可變長度,最多65535個字符

mediumtext 可變長度,最多2的24次方-1個字符

longtext 可變長度,最多2的32次方-1個字符

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 正阳县| 晋城| 京山县| 改则县| 泸定县| 泾川县| 枝江市| 永安市| 漳浦县| 民权县| 寻乌县| 东阿县| 鲁甸县| 盐池县| 天长市| 巧家县| 昌吉市| 常德市| 行唐县| 黄梅县| 台东县| 新巴尔虎右旗| 理塘县| 宜兰市| 慈溪市| 明水县| 武平县| 荥阳市| 沁水县| 崇信县| 牟定县| 龙江县| 高清| 潮州市| 健康| 霍林郭勒市| 石屏县| 酉阳| 安塞县| 榆林市| 汝州市|