zoukankan      html  css  js  c++  java
  • MySQL数据库中几种数据类型的长度

    在MySQL里新建表自然会涉及设置字段长度,但有时会发现长度限制在一些字段类型中不起作用?字段长度是按字节算还是字符算?

    如图中:int看起来只要还在本身类型取值范围内就行,字段长度没有起到作用;而char确实被限制在了5个字符中,甚至不是字节。

    背后玄机在于不同数据类型的规则不同。

    1、整数类型

    这里的宽度和数据类型的取值是没有关系的,显示宽度只指明Mysql最大可能显示的数字个数,数值的位数小于指定的宽度时会由空格填充;如果插入了大于显示宽度的值,只要该值不超过该类型的取值范围,数值依然可以插入,而且能够显示出来。

    例如int整型只要数值在-2147483648~2147483647之间,不会出问题,连警告都没有

    若不设置字段长度,系统会默认tinyint(4),smallint(6),mediumint(9),int(11),bigint(20),也就是他们的取值范围。

    2、字符型

    宽度就有用了,确确实实限制了无论是char或者varchar,超出字段长度的内容将会丢失。当然,对于varchar设置255也不会浪费,毕竟是变长存储

    3、浮点

    浮点就没什么疑问了,按照他自己的规则来。这里是3个数,小数后2位,输入超范围就输出最大的就完事了

  • 相关阅读:
    B-Tree和B+Tree的区别
    b树和hash树的应用场景
    比较顺序表和链表的优缺点,说说它们分别在什么场景下使用?
    5V与3.3V电平互转
    100M双绞线接头的标准接法
    解决openwrt中文界面异常
    刚刚开通了博客
    openwrt挂载摄像头及视频保存
    mwan3多wan叠加成功
    贝尔金(Belkin)7231-4P tftp救砖
  • 原文地址:https://www.cnblogs.com/hereisdavid/p/13462375.html
Copyright © 2011-2022 走看看