MySQL 如何使用 YEAR 数据类型在表中存储年份值?

MySQL 如何使用 YEAR 数据类型在表中存储年份值?

在 MySQL 数据库中,YEAR 数据类型用于存储两位数或四位数格式的年份值。YEAR 类型值的最小值为 1901 年,最大值为 2155 年。通过使用 YEAR 数据类型,可以将年份值存储为数字格式,并且可以进行各种年份相关的计算。

下面将详细介绍 MySQL 中如何使用 YEAR 数据类型在表中存储年份值。

创建表时使用 YEAR 数据类型存储年份值

当需要在 MySQL 数据库中创建一张表用于存储年份值时,可以使用 YEAR 数据类型来创建该表的字段。例如,创建一张名为 "books" 的图书表,并用 YEAR 类型的字段 "publish_year" 存储出版年份值。

CREATE TABLE books (

id INT(11) NOT NULL AUTO_INCREMENT,

title VARCHAR(255) NOT NULL,

author VARCHAR(255) NOT NULL,

publish_year YEAR(4) NOT NULL,

PRIMARY KEY (id)

);

在上述代码中,使用 YEAR(4) 数据类型创建了长度为 4 的 YEAR 字段 "publish_year",该字段用于存储出版年份值。

插入 YEAR 类型的年份值

插入数据时,可以使用专用的 YEAR() 函数将年份值转换成 MySQL 的 YEAR 类型格式。例如,将 2021 年作为出版年份插入 books 表中:

INSERT INTO books (title, author, publish_year)

VALUES ('MySQL 数据库教程', '张三', YEAR('2021'));

在插入数据时,使用 YEAR() 函数将数字类型的年份值转换成 YEAR 数据类型并进行插入操作。

查询 YEAR 类型的年份值

在查询 YEAR 类型的年份值时,可以直接在 SQL 语句中使用 YEAR 类型的字段。例如,查询 2021 年发布的图书:

SELECT * FROM books WHERE publish_year = '2021';

在上述代码中,使用 WHERE 子句过滤出发表年份为 2021 年的图书。

YEAR 类型值的计算

在 MySQL 数据库中,可以使用 YEAR() 函数将 YEAR 类型的值转换成整数型。例如,将 2021 年转换成整数型:

SELECT YEAR('2021');

上述代码的输出结果为 2021,将 YEAR 类型的年份值提取出来变成了整数型。

可以在 SQL 查询中对 YEAR 类型的字段进行计算。例如,查询 2020 年之后发表的图书:

SELECT * FROM books WHERE publish_year > YEAR('2020');

在上述代码中,使用 WHERE 子句过滤出出版日期晚于 2020 年的图书。

日期范围查询

可以使用 BETWEEN 子句和 YEAR 类型的值进行日期范围查询。例如,查询 2000 年到 2020 年之间发布的图书:

SELECT * FROM books WHERE publish_year BETWEEN '2000' AND '2020';

在上述代码中,使用 BETWEEN 子句过滤出发表年份在 2000 年到 2020 年之间的图书。

总结

通过使用 YEAR 数据类型,可以将年份值存储为数字型,并可进行各种年份相关的计算。在使用 YEAR 数据类型的时候,需要注意长度和范围,以及插入和查询时的 YEAR() 函数的应用。

本篇文章介绍了在 MySQL 中使用 YEAR 数据类型存储年份值的相关知识。希望本文对读者对 MySQL 数据库的理解有所帮助。

数据库标签