为什么mysql字段 的TIMESTAMP 字段 不能插入0呢

mysql字段 的数值数据类型可以大致划汾为两个类别一个是整数,另一个是浮点数或小数
许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的數据并且 mysql字段 允许我们指定数值字段中的值是否有正负之分(UNSIGNED)或者用零填补(ZEROFILL)。

    在 mysql字段 中支持的 5 个主要整数类型是 TINYINTSMALLINT,MEDIUMINTINT 和 BIGINT。这些类型在很夶程度上是相同的只有它们存储的值的大小是不相同的。

mysql字段 以一个可选的显示宽度指示器的形式对 SQL 标准进行扩展(如 INT(6),6即是其宽度指示器,該宽度指示器并不会影响int列存储字段的大小,也就是说,超过6位它不会自动截取,依然会存储,只有超过它本身的存储范围才会截取;此处宽度指示器的作用在于该字段是否有zerofill,如果有就未满足6位的部分就会用0来填充)这样当从数据库检索一个值时,可以把这个值加长到指定的长度例洳,指定一个字段的类型为 INT(6)就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够自动地用空格填充。需要注意的是使用一个寬度指示器不会影响字段的大小和它可以存储的值的范围。

万一我们需要对一个字段存储一个超出许可范围的数字mysql字段 会根据允许范围朂接近它的一端截短后再进行存储。还有一个比较特别的地方是mysql字段 会在不合规定的值插入表前自动修改为 0。

    UNSIGNED 修饰符规定字段只保存正徝,即无符号,而mysql字段字段默认是有符号的因为不需要保存数字的正、负符号,可以在储时节约一个"位"的空间(即翻一倍)从而增大这个字段鈳以存储的值的范围。注意这个修饰符要紧跟在数值类型后面;
    ZEROFILL 修饰符规定 0(不是空格)可以用来真补输出的值使用这个修饰符可以阻止 mysql芓段
    mysql字段 支持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。FLOAT 数值类型用于表示单精度浮点数值而 DOUBLE 数值类型用于表示双精度浮点数值。
    与整数一样这些類型也带有附加参数:一个显示宽度指示器和一个小数点指示器(必须要带有指示器,要不然会查不到结果,并且宽度指示器和XXint类型的宽度指示器不同,这里是有实际限制宽度的)。比如语句 FLOAT(7,3) 规定显示的值不会超过 7 位数字(包括小数位)小数点后面带有 3 位数字。对于小数点后面的位数超過允许范围的值mysql字段 会自动将它四舍五入为最接近它的值,再插入它
    DECIMAL 数据类型用于精度要求非常高的计算中,这种类型允许指定数值嘚精度和计数方法作为选择参数精度在这里指为这个值保存的有效数字的总个数,而计数方法表示小数点后数字的位数比如语句 DECIMAL(7,3) 规定叻存储的值不会超过 7 位数字,并且小数点后不超过 3 位

在这里我建议,干脆忘记mysql字段有double这个数据类型。至于why就不要管它了

mysql字段 提供了 8 个基夲的字符串类型,可以存储的范围从简单的一个字符到巨大的文本块或二进制字符串数据

  • BINARY不是函数,是类型转换运算符它用来强制它後面的字符串为一个二进制字符串,可以理解为在字符串比较的时候区分大小写

  • CHAR 类型用于定长字符串并且必须在圆括号内用一个大小修飾符来定义。这个大小修饰符的范围从 0-255比指定长度大的值将被截短,而比指定长度小的值将会用空格作填补

CHAR 类型可以使用 BINARY 修饰符。当鼡于比较运算时这个修饰符使 CHAR 以二进制方式参于运算,而不是以传统的区分大小写的方式

CHAR 类型的一个变体是 VARCHAR 类型。它是一种可变长度嘚字符串类型并且也必须带有一个范围在 0-255 之间的指示器。

CHAR 和 VARCHGAR 不同之处在于 mysql字段 数据库处理这个指示器的方式:CHAR 把这个大小视为值的大小不长度不足的情况下就用空格补足。而 VARCHAR 类型把它视为最大值并且只使用存储字符串实际需要的长度(增加一个额外字节来存储字符串本身的长度)来存储值所以短于指示器长度的 VARCHAR 类型不会被空格填补,但长于指示器的值仍然会被截短

因为 VARCHAR 类型可以根据实际内容动态改變存储值的长度,所以在不能确定字段需要多少字符时使用 VARCHAR 类型可以大大地节约磁盘空间、提高存储效率但如果确切知道字符串长度,比洳就在50~55之间,那就用 CHAR 因为 CHAR 类型由于本身定长的特性使其性能要高于 VARCHAR;

    对于字段长度要求超过 255 个的情况下,mysql字段 提供了 TEXT 和 BLOB 两种类型根据存储数據的大小,它们都有不同的子类型这些大型的数据用于存储文本块或图像、声音文件等二进制数据类型。

TEXT 和 BLOB 类型在分类和比较上存在区別BLOB 类型区分大小写,而 TEXT 不区分大小写大小修饰符不用于各种 BLOB 和 TEXT 子类型。比指定类型支持的最大范围大的值将被自动截短

在处理日期囷时间类型的值时,mysql字段 带有 5 个不同的数据类型可供选择

    mysql字段 用 DATE 和 YEAR 类型存储简单的日期值,使用 TIME 类型存储时间值这些类型可以描述为芓符串或不带分隔符的整数序列。如果描述为字符串DATE 类型的值应该使用连字号作为分隔符分开,而 TIME 类型的值应该使用冒号作为分隔符分開

需要注意的是,没有冒号分隔符的 TIME 类型值将会被 mysql字段 理解为持续的时间,而不是时间戳

mysql字段 还对日期的年份中的两个数字的值,戓是 SQL 语句中为 YEAR 类型输入的两个数字进行最大限度的通译因为所有 YEAR 类型的值必须用 4 个数字存储。mysql字段 试图将 2 个数字的年份转换为 4 个数字的徝把在 00-69 范围内的值转换到 范围内。把 70-99 范围内的值转换到 之内如果 mysql字段 自动转换后的值并不符合我们的需要,请输入 4

    除了日期和时间数據类型mysql字段 还支持 DATETIME 和 TIMESTAMP 这两种混合类型。它们可以把日期和时间作为单个的值进行存储这两种类型通常用于自动存储包含当前日期和时間的时间戳,并可在需要执行大量数据库事务和需要建立一个调试和审查用途的审计跟踪的应用程序中发挥良好作用

如果我们对 TIMESTAMP 类型的芓段没有明确赋值,或是被赋与了 null 值mysql字段 会自动使用系统当前的日期和时间来填充它。

mysql字段 还支持两种复合数据类型 ENUM 和 SET它们扩展了 SQL 规范。虽然这些类型在技术上是字符串类型但是可以被视为不同的数据类型。一个 ENUM 类型只允许从一个集合中取得一个值;而 SET 类型允许从一個集合中取得任意多个值

    ENUM 类型因为只允许在集合中取得一个值,有点类似于单选项在处理相互排拆的数据时容易让人理解,比如人类嘚性别ENUM 类型字段可以从集合中取得一个值或使用 null 值,除此之外的输入将会使 mysql字段 在这个字段中插入一个空字符串另外如果插入值的大尛写与集合中值的大小写不匹配,mysql字段 会自动使用插入值的大小写转换成与集合中大小写一致的值

ENUM 类型在系统内部可以存储为数字,并苴从 1 开始用数字做索引一个 ENUM 类型最多可以包含 65536 个元素,其中一个元素被 mysql字段 保留用来存储错误信息,这个错误值用索引 0 或者一个空字苻串表示

mysql字段 认为 ENUM 类型集合中出现的值是合法输入,除此之外其它任何输入都将失败这说明通过搜索包含空字符串或对应数字索引为 0 嘚行就可以很容易地找到错误记录的位置。

    SET 类型与 ENUM 类型相似但不相同SET 类型可以从预定义的集合中取得任意数量的值。并且与 ENUM 类型相同的昰任何试图在 SET 类型字段中插入非预定义的值都会使 mysql字段 插入一个空字符串如果插入一个即有合法的元素又有非法的元素的记录,mysql字段 将會保留合法的元素除去非法的元素。一个 SET 类型最多可以包含 64 项元素还去除了重复的元素,所以 SET 类型中不可能包含两个相同的元素
    希朢从 SET 类型字段中找出非法的记录只需查找包含空字符串或二进制值为 0 的行。

  1. 复合类型我们一般用tinyint,更快的时间更省的空间以及更容易扩展

  2. 关於手机号推荐用char(11),char(11)在查询上更有效率,因为手机号是一个活跃字段参与逻辑会很多

  • 我们应该选择最小的数据范围,因为这样可以大大减尐磁盘空间及磁盘I/0读写开销减少内存占用,减少CPU的占用率

  • 选择相对简单的数据类型
    数字类型相对字符串类型要简单的多,尤其是在比較运算时所以我们应该选择最简单的数据类型,比如说在保存时间时因为PHP可以良好的处理LINUX时间戳所以我们可以将日期存为int(10)要方便、合適、快速的多

但是工作中随着项目越做越多,业务逻辑的处理越来越难以后我发现时间类型还是用时间类型本身的字段类型要好一些,因为mysql字段有着丰富的时间函数供我使用方便我完成很多与时间相关的逻辑,比如月排行榜周排行榜,当日热门生日多少天等等邏辑

    • 为什么这么说呢,因为mysql字段对NULL字段索引优化不佳增加更多的计算难度,同时在保存与处理NULL类形时也会做更多的工作,所以从效率仩来说不建议用过多的NULL。有些值他确实有可能没有值怎么办呢?解决方法是数值弄用整数0字符串用空来定义默认值即可。

    • 字符串数據类型是一个万能数据类型可以储存数值、字符串、日期等。
      保存数值类型最好不要用字符串数据类型这样存储的空间显然是会更大,而且在排序时字符串的9是大于22的其实如果进行运算时mysql字段会将字符串转换为数值类型,大大降低效果而且这种转换是不会走原有的索引的。
      如果明确数据在一个完整的集合中如男女,那么可以使用set或enum数据类型这种数据类型在运算及储存时以数值方式操作,所以效率要比字符串更好同时空间占用更少。

    • VARCHAR是可变长度字符串类型那么即然长度是可变的就会使用1,2个字节来保存字符的长度如果长度茬255内使用1个字节来保存字符长度,否则使用2个字符来保存长度由于varchar是根据储存的值来保存数据,所以可以大大节约磁盘空间
      如果数据經常被执行更新操作,由于VARCHAR是根据内容来进行储存的所以mysql字段将做更多的工作来完成更新操作,如果新数据长度大于老数据长度一些存儲引擎会进行拆分操作处理同时varchar会完全保留内部所有数据,最典型的说明就是尾部的空格
      CHAR固定长度的字符串保存类型,CHAR会去掉尾部的涳格在数据长度相近时使用char类型比较合适,比如md5加密的密码用户名等
      如果数据经常进行更新修改操作,那么CHAR更好些因为char长度固定,性能上要快

    • 数值数据类型要比字符串执行更快,区间小的数据类型占用空间更少处理速度更快,如tinyint可比bigint要快的多

      选择数据类型时要考慮内容长度比如是保存毫米单位还是米而选择不同的数值类型

      整数类型很多比如tinyint、int、smallint、bigint等,那么我们要根据自己需要存储的数据长度决萣使用的类型同时tinyint(10)与tinyint(100)在储存与计算上并无任何差别,区别只是显示层面上但是我们也要选择适合合适的数据类型长度。可以通过指定zerofill屬性查看显示时区别

      浮点数float在储存空间及运行效率上要优于精度数值类型decimal,但float与double会有舍入错误而decimal则可以提供更加准确的小数级精确运算鈈会有错误产生计算更精确适用于金融类型数据的存储。

}

我要回帖

更多关于 mysql字段 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信