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位,输入超范围就输出最大的就完事了

  • 相关阅读:
    计算机基础总结
    Apache安装错误 APR not found解决方法
    一、编译错误
    2.2 进程控制之进程共享
    2.1 进程控制之fork创建子进程
    ARM串口控制终端命令
    u-boot、kernel、root系统烧写和挂载命令命令
    8.1 编写USB鼠标驱动程序,并测试
    八、USB驱动分析
    Source Insight的使用
  • 原文地址:https://www.cnblogs.com/hereisdavid/p/13462375.html
Copyright © 2011-2022 走看看