zoukankan      html  css  js  c++  java
  • Mysql的BigInt(20),Int(20)以及Bigint(32)有区别吗?

    原文: http://stackoverflow.com/questions/3135804/types-in-mysql-bigint20-vs-int20-etcc

    http://dev.mysql.com/doc/refman/5.1/en/numeric-types.html

    Types in MySQL: BigInt(20) vs Int(20) etcc

    See http://dev.mysql.com/doc/refman/5.1/en/numeric-types.html

    INT is a four-byte signed integer. BIGINT is an eight-byte signed integer.

    The 20 in INT(20) and BIGINT(20) means almost nothing. It's a hint for display width, it has nothing to do with storage. Practically, it affects only the ZEROFILL option:

    Sql代码  收藏代码
    1. CREATE TABLE foo ( bar INT(20) ZEROFILL );  
    2. INSERT INTO foo (bar) VALUES (1234);  
    3. SELECT bar from foo;  
    4.   
    5. +----------------------+  
    6. | bar                  |  
    7. +----------------------+  
    8. | 00000000000000001234 |  
    9. +----------------------+  
     

    The number in parentheses in a type declaration is display width , which is unrelated to the range of values that can be stored in a data type. Just because you can declare Int(20) does not mean you can store values up to 10^20 in it:

    [...] This optional display width may be used by applications to display integer values having a width less than the width specified for the column by left-padding them with spaces. ...

    The display width does not constrain the range of values that can be stored in the column, nor the number of digits that are displayed for values having a width exceeding that specified for the column. For example, a column specified as SMALLINT(3) has the usual SMALLINT range of -32768 to 32767, and values outside the range allowed by three characters are displayed using more than three characters.

    For a list of the maximum and minimum values that can be stored in each MySQL datatype, see here .

    Mysql的数字类型(1B,2B,3B,4B,8B都有)

    一个INT,占4个字节,跟JAVA中的int一样,即使是有符号也能表达21亿 这么大的数据。 所以平时绝大多数情况,包括大型网站的UID,都用不了这么大的数据,好友关系表可能会超过,关系表可以考虑用BIGINT。还有就是平时时间戳需要用BIGINT。总之,不要轻易用上BIGINT,完全是浪费!

  • 相关阅读:
    java 死锁
    阿里云 zookeeper
    spring 单元测试
    java hashmap分段锁实现
    java lambda 列表生成列表
    springAOP简介
    spring IOC小知识点
    spring中相互依赖的问题
    linux学习02-虚拟机安装CentOS之后联网
    linux学习01-虚拟机VirtualBox上安装centos7,小白第一步
  • 原文地址:https://www.cnblogs.com/yuhuameng/p/11429543.html
Copyright © 2011-2022 走看看