Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

เราจะแยกปีและเดือนออกจากวันที่ใน MySQL ได้อย่างไร


สามารถทำได้ด้วยสามวิธีต่อไปนี้ใน MySQL

โดยใช้ฟังก์ชัน EXTRACT()

สำหรับการแยก YEAR และ MONTH รวมกัน เราสามารถใช้ฟังก์ชัน EXTRACT ได้ เราจำเป็นต้องระบุ YEAR_MONTH เป็นอาร์กิวเมนต์สำหรับฟังก์ชันนี้ เพื่อให้เข้าใจ ให้พิจารณาฟังก์ชันต่อไปนี้โดยใช้ข้อมูลจากตาราง 'Collegedetail' -

mysql> Select EXTRACT(YEAR_MONTH From estb) from collegedetail;
+-------------------------------+
| EXTRACT(YEAR_MONTH From estb) |
+-------------------------------+
|                        201005 |
|                        199510 |
|                        199409 |
|                        200107 |
|                        201007 |
+-------------------------------+
5 rows in set (0.00 sec)

โดยใช้ฟังก์ชัน DATE_FORMAT()

สามารถแยกปีและเดือนแบบรวมและแยกกันได้ ตามชื่อที่แนะนำ เราสามารถจัดรูปแบบผลลัพธ์ได้ เพื่อให้เข้าใจ ให้พิจารณาตัวอย่างต่อไปนี้ซึ่งใช้ข้อมูลจากตาราง 'Collegedetail' -

mysql> Select DATE_FORMAT(estb, '%Y %m') from collegedetail;
+----------------------------+
| DATE_FORMAT(estb, '%Y %m') |
+----------------------------+
| 2010 05                    |
| 1995 10                    |
| 1994 09                    |
| 2001 07                    |
| 2010 07                    |
+----------------------------+
5 rows in set (0.00 sec)

mysql> Select DATE_FORMAT(estb, '%Y') from Collegedetail;
+-------------------------+
| DATE_FORMAT(estb, '%Y') |
+-------------------------+
| 2010                    |
| 1995                    |
| 1994                    |
| 2001                    |
| 2010                    |
+-------------------------+
5 rows in set (0.00 sec)

mysql> Select DATE_FORMAT(estb, '%m') from Collegedetail;
+-------------------------+
| DATE_FORMAT(estb, '%m') |
+-------------------------+
| 05                      |
| 10                      |
| 09                      |
| 07                      |
| 07                      |
+-------------------------+
5 rows in set (0.00 sec)

mysql> Select DATE_FORMAT(estb, '%M') from Collegedetail;
+-------------------------+
| DATE_FORMAT(estb, '%M') |
+-------------------------+
| May                     |
| October                 |
| September               |
| July                    |
| July                    |
+-------------------------+
5 rows in set (0.10 sec)

โดยการใช้สองฟังก์ชันที่แตกต่างกัน YEAR() และ MONTH()

จะแยกปีและเดือนแยกกันโดยใช้ฟังก์ชันที่แตกต่างกันสองแบบ เพื่อให้เข้าใจ ให้พิจารณาตัวอย่างต่อไปนี้ซึ่งใช้ข้อมูลจากตาราง 'Collegedetail' -

mysql> Select YEAR(estb) AS 'Year', MONTH(estb) As 'MONTH' From collegedetail;
+------+-------+
| Year | MONTH |
+------+-------+
| 2010 |     5 |
| 1995 |    10 |
| 1994 |     9 |
| 2001 |     7 |
| 2010 |     7 |
+------+-------+
5 rows in set (0.00 sec)