1.tinyint 1Bytes -128~127(255)
2.smallint 2Bytes -32768~32676(65535)
3.mdeiumint 3Bytes -8388608~8388607(16777215)
4.int 4Bytes -2147483648~2147483647(4294967295,42亿)
5.bigint 8Bytes -9223372036854775808~9223372036854775807(18446744073709551615)
int列如果是主键不能online DDL 转成bigint.
int(11),11是修饰符,不是长度限制,int(8)zerofill zerofill也是修饰符,左侧补零.
溢出:
cast(9223372036854775807 as unsigned) 改为不符号
IPv4地址可以用INT存储:
select length(‘255.255.255.255‘)
+---------------------------+
| length(‘255.255.255.255‘) |
+---------------------------+
| 15 |
+---------------------------+
root@localhost [(none)]>select inet_aton(‘255.255.255.255‘); //IPv4最大值,正好是int的无符号数最大值.
+------------------------------+
| inet_aton(‘255.255.255.255‘) |
+------------------------------+
| 4294967295 |
+------------------------------+
root@localhost [(none)]>select inet_ntoa(4294967295);
+-----------------------+
| inet_ntoa(4294967295) |
+-----------------------+
| 255.255.255.255 |
+-----------------------+
IPv6和IPv4共用的方法(数据类型为VARBINARY(16),而不是BINARY(16)。唯一的原因是MySQL函数同时适用于IPv6和IPv4地址。 BINARY(16)只适用于存储IPv6地址,并保存一个字节。在处理IPv6和IPv4地址时应使用VARBINARY(16)):
root@localhost [(none)]>SELECT HEX(INET6_ATON(‘fdfe::5a55:caff:fefa:9089‘));
+----------------------------------------------+
| HEX(INET6_ATON(‘fdfe::5a55:caff:fefa:9089‘)) |
+----------------------------------------------+
| FDFE0000000000005A55CAFFFEFA9089 |
+----------------------------------------------+
1 row in set (0.00 sec)
root@localhost [(none)]>SELECT HEX(INET6_ATON(‘192.168.9.1‘));
+--------------------------------+
| HEX(INET6_ATON(‘192.168.9.1‘)) |
+--------------------------------+
| C0A80901 |
+--------------------------------+
1 row in set (0.00 sec)
mysql> SELECT INET6_NTOA(INET6_ATON(‘fdfe::5a55:caff:fefa:9089‘));
-> ‘fdfe::5a55:caff:fefa:9089‘
mysql> SELECT INET6_NTOA(INET6_ATON(‘192.168.9.1‘));
-> ‘192.168.9.1‘
mysql> SELECT INET6_NTOA(UNHEX(‘FDFE0000000000005A55CAFFFEFA9089‘));
-> ‘fdfe::5a55:caff:fefa:9089‘
mysql> SELECT INET6_NTOA(UNHEX(‘C0A80901‘));
-> ‘192.168.9.1‘
优先使用:timestamp,其次datetime
timetamp\datetime 从5.6.6开始均支持自动更新为current_timestamp
日期转换:
CAST()datetime_col as DATE)
SELECT NOW()+0;
root@localhost [wenyz]>SELECT NOW()+0;
+----------------+
| NOW()+0 |
+----------------+
| 20181016075647 |
+----------------+
1 row in set (0.00 sec)
root@localhost [wenyz]>SELECT NOW();
+---------------------+
| NOW() |
+---------------------+
| 2018-10-16 07:56:54 |
+---------------------+
1 row in set (0.00 sec)
root@localhost [wenyz]>select CAST(now() as DATE)
-> ;
+---------------------+
| CAST(now() as DATE) |
+---------------------+
| 2018-10-16 |
+---------------------+
1 row in set (0.00 sec)
root@localhost [wenyz]>select CAST(now() as DATE);
+---------------------+
| CAST(now() as DATE) |
+---------------------+
| 2018-10-16 |
+---------------------+
1 row in set (0.00 sec)
root@localhost [wenyz]>select CAST(now() as time);
+---------------------+
| CAST(now() as time) |
+---------------------+
| 07:57:53 |
+---------------------+
1 row in set (0.00 sec)
root@localhost [wenyz]>select now(),now()+5;
+---------------------+----------------+
| now() | now()+5 |
+---------------------+----------------+
| 2018-10-16 07:59:36 | 20181016075941 |
+---------------------+----------------+
1 row in set (0.00 sec)
1.char(M) Mw(字符集的单字符字节数) bytes,0<=M<=255 (utf8 2553,utf8.mb4:2554)
2.BINARY(M) M bytes,0<=M<=255
3.VARCHAR(M),VARBINARY(M) L+1 bytes if column values require 0-255 bytes if values may require more than 255 bytes,L+2bytes if values may require more than 255 bytes.(除Mw都需要额外1或2个节点存信息),实际存储长度超过255字节时,会被做TEXT处理.所有VARCHAR列的总可用长度是65535字节(实际上是65533)
字符集是utf8mb4时,实际可存储字符数是FLOOR(65533/4)=16384
4.mysql8.0默认字符集是utf8mb4
data type | storange required |
---|---|
tinyblob,tinytext | L+1bytes,where L<2^8 |
Blob,text | L+1bytes,where L<2^16 |
mediumblob,mediumtext | L+4bytes,where L<2^24 |
longlob,longtext | L+4bytes,where L<2^32 |
实例:一个100G的表拆分成4个表后,总大小仅25G
小数点后面的位数超限后,自动四舍五入(SQL_MODE=‘‘时)
ENMU(VALUE_LIST)
或者使用TokuDB引擎
不同的表
存储.原文:https://www.cnblogs.com/2woods/p/9862680.html