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

  • 相关阅读:
    软件工程第二次作业
    第一次作业
    理论物理特训-02
    左神-06 二叉树
    哲学通论之人-05(end)
    哲学通论之人-04
    左神-05 二分搜索(多看几遍)
    哲学通论之人-01
    航空母舰-04(end)
    题解 P3126 【[USACO15OPEN]回文的路径Palindromic Paths】
  • 原文地址:https://www.cnblogs.com/hereisdavid/p/13462375.html
Copyright © 2011-2022 走看看