为什么在 MySQL 中使用两位数年份的日期值不是一个好习惯?

PHPz
发布: 2023-09-06 20:25:02
转载
1362 人浏览过

为什么在 MySQL 中使用两位数年份的日期值不是一个好习惯?

众所周知,YEAR(2) 以 2 位数字格式存储年份。例如,我们可以写 69 将 1969 存储为年份。在 YEAR (2) 中,年份可以指定为 1970 到 2069(70 到 69)。

MySQL 借助以下规则解释 2 位年份值 -

  • 00-69 范围内的年份值将转换为 2000-2069。
  •  70-99 范围内的年份值将转换为 1970-1999。
  • ul>

    我们不能将日期值存储为 2 位数字格式,因为由于世纪未知,以这种格式存储的值会变得模糊。

    借助以下 MySQL 可以更清楚地理解它示例 -

    mysql> Create Table year_test(val year(2));
    Query OK, 0 rows affected, 1 warning (0.23 sec)
    
    mysql> insert into year_test(val) values('70');
    Query OK, 1 row affected (0.14 sec)
    
    mysql> insert into year_test(val) values('00');
    Query OK, 1 row affected (0.06 sec)
    
    mysql> select * from year_test;
    +-----+
    | val |
    +-----+
    | 70  |
    | 00  |
    +-----+
    2 rows in set (0.00 sec)
    
    mysql> select * from year_test where val = '1970';
    +-----+
    | val |
    +-----+
    | 70  |
    +-----+
    1 row in set (0.03 sec)
    
    mysql> select * from year_test where val = '2000';
    +-----+
    | val |
    +-----+
    | 00  |
    +-----+
    1 row in set (0.00 sec)
    
    mysql> select * from year_test where val = '1900';
    Empty set (0.06 sec)
    登录后复制

    通过将 00 存储到“val”,我们不确定是指哪一年,“1900”还是“2000”。 MySQL 将其解释为 2000 年。

以上是为什么在 MySQL 中使用两位数年份的日期值不是一个好习惯?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!