Mysql數據類型
1. 數值類型:
包括整數類型TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT、浮點小數數據類型FLOAT和DOUBLE,定點小數類型DECIMAL。
類型 | 存儲 | 范圍(有符號) | 無符號 |
---|---|---|---|
TINYINT | 1字節 | -128~127 | 0~255() |
SMALLINT | 2字節 | 32768~32767 | 0~65535 |
MEDIUMINT | 3字節 | -8388608~8388607 | 0~16777215 |
INT | 4字節 | -2147483648~2147483647 | 0~4294967295 |
BIGINT | 8字節 | ||
FLOAT | 4字節 | ||
DOUBLE | 8字節 | ||
DECIMAL(M,N) | M+2字節 |
注意:
CREATE TABLE test1(
id INT(3),
`name` VARCHAR(5),
age INT(3)
);
id INT(3)
括號內的3不是限制存儲數據的大小,而是指示顯示寬度.顯示寬度和數據類型的取值范圍是無關的
顯示寬度只用於顯示,並不能限制取值范圍和占用空間。例如:INT(3)會占用4字節的存儲空間,並且允許的最大值不會是999,而是INT整型所允許的最大值。顯示寬度只是指明MySQL最大可能顯示的數字個數,數值的位數小於指定的寬度時會由空格填充
例如:向test1
入id = 999999
的數據還是會成功.
INSERT INTO test1 VALUES(999999,'小明',12);
select * from test1 where id = 999999;
id name age
999999 小明 12
DECIMAL。浮點數類型和定點數類型都可以用(M,N)來表示。其中,M稱為精度,表示總共的位數;N稱為標度,表示小數的位數.DECIMAL若不指定精度則默認為(10,0)
不論是定點數還是浮點數類型,如果用戶指定的精度超出精度范圍,則會四舍五入
CREATE TABLE test2(
id INT(4),
score DECIMAL(3,2)
);
INSERT INTO test2 VALUES(1,5.123),(2, 5.236),(3,5.1);
SELECT * FROM test2;
-- 結果
id score
1 5.12
2 5.24
3 5.10
如果插入大於999.99
的數就會報錯了
insert into test2 values(4, 1000.4567);
-- 結果
查詢:insert into test2 values(4, 1000.4567)
錯誤代碼: 1264
Out of range value for column 'score' at row 1
2. 日期/時間類型:
包括YEAR、TIME、DATE、DATETIME和TIMESTAMP
類型 | 日期格式 | 范圍 | |
---|---|---|---|
YEAR | YYYY | 1901-2155 | 1字節 |
TIME | HH:MM:SS | 3字節 | |
DATE | YYYY-MM-DD | 3字節 | |
DATETIME | YYYY-MM-DD HH:MM:SS | 8字節 | |
TIMESTAMP | YYYY-MM-DD HH:MM:SS | 4字節 |
注意: TIMESTAMP的范圍是1970年到2038年
TIMESTAMP與DATETIME除了存儲字節和支持的范圍不同外,還有一個最大的區別就是:DATETIME在存儲日期數據時,按實際輸入的格式存儲,即輸入什么就存儲什么,與時區無關;而TIMESTAMP值的存儲是以UTC(世界標准時間)格式保存的,存儲時對當前時區進行轉換,檢索時再轉換回當前時區。查詢時,不同時區顯示的時間值是不同的。
DATE:
(1)以‘YYYY-MM-DD’或者‘YYYYMMDD’字符串格式表示的日期,取值范圍為‘1000-01-01’~‘9999-12-3’。例如,輸入‘2012-12-31’或者‘20121231’,插入數據庫的日期都為2012-12-31。
(2)以‘YY-MM-DD’或者‘YYMMDD’字符串格式表示的日期,在這里YY表示兩位的年值。包含兩位年值的日期會令人模糊,因為不知道世紀。MySQL使用以下規則解釋兩位年值:‘00~69’范圍的年值轉換為‘2000~2069’;‘70~99’范圍的年值轉換為‘1970~1999’。例如,輸入‘12-12-31’,插入數據庫的日期為2012-12-31;輸入‘981231’,插入數據的日期為1998-12-31。
(3)以YY-MM-DD或者YYMMDD數字格式表示的日期,與前面相似,00~69范圍的年值轉換為2000~2069,70~99范圍的年值轉換為1970~1999。例如,輸入12-12-31插入數據庫的日期為2012-12-31;輸入981231,插入數據的日期為1998-12-31
3. 字符串類型:
包括CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET等。字符串類型又分為文本字符串和二進制字符串
類型 | 存儲 | 大小 | |
---|---|---|---|
CHAR(M) | M字節,1 <= M <=255 | ||
VARCHAR | L+1字節, L<= M , | ||
TINYTEXT | 0-255 字節 | ||
TEXT | 0-65535 字節 | ||
MEDIUMTEXT | 0-16,777,215 字節 | ||
LONGTEXT | 0-4,294,967,295 or 4GB 字節 | ||
ENUM | 1或2字節 | ||
TINYBLOB | 0-255 字節 | ||
BLOB | 0-65535 字節 | ||
MEDIUMBLOB | 0-16,777,215 字節 | ||
LONGBLOB | 0-4,294,967,295 or 4GB 字節 |
varchar(M)
說明 括號內的M和INT(4)
類型的限制不一樣,這里M對插入數據的長度有限制,超長就會報錯
CREATE TABLE test3(
id INT(4),
`name` VARCHAR(5),
`remark` varchar(1000)
);
insert into test3 values(1, '小紅','第一條數據');
-- 數據正常插入
id name remark
1 小紅 第一條數據
數據超長情況
insert into test3 values(1, '這個名字真長','第二條數據');
-- 顯示name字段超長
<e>查詢:insert into test3 values(1, '這個名字真長','第二條數據')
錯誤代碼: 1406
Data too long for column 'name' at row 1
INSERT INTO test3 VALUES(1, 'abcdef','第三條數據');
-- 顯示還是超長
查詢:INSERT INTO test3 VALUES(1, 'abcdef','第三條數據')
錯誤代碼: 1406
Data too long for column 'name' at row 1
varchar字段長度直接按字符計算不區分中英文字符
本文由博客一文多發平台 OpenWrite 發布!