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

เราจะคำนวณวันที่ใน MySQL โดยใช้ฟังก์ชันได้อย่างไร


ใน MySQL เราสามารถใช้ฟังก์ชันต่อไปนี้เพื่อคำนวณวันที่ −

  • CURDATE() ฟังก์ชัน - โดยทั่วไปจะส่งกลับวันที่ปัจจุบันของคอมพิวเตอร์
  • YEAR() ฟังก์ชัน - ส่งกลับปีของวันที่ระบุ
  • ฟังก์ชัน MONTH() - ส่งกลับเดือนของวันที่ระบุ
  • DAY() ฟังก์ชัน - ส่งกลับวันที่ของวันที่ระบุ
  • RIGHT() ฟังก์ชัน - ส่งคืนจำนวนอักขระตามที่ระบุในฟังก์ชันจากวันที่ที่กำหนด ส่วนของนิพจน์ที่เปรียบเทียบผลตอบแทนจากฟังก์ชัน RIGHT() จะประเมินค่า 1 หรือ 0

เพื่อให้เข้าใจ ให้พิจารณาข้อมูลดังต่อไปนี้ จากตารางชื่อ 'Collegedetail' −

mysql> Select * from Collegedetail;
+------+---------+------------+
| ID   | Country | Estb       |
+------+---------+------------+
| 111  | INDIA   | 2010-05-01 |
| 130  | INDIA   | 1995-10-25 |
| 139  | USA     | 1994-09-25 |
| 1539 | UK      | 2001-07-23 |
| 1545 | Russia  | 2010-07-30 |
+------+---------+------------+
5 rows in set (0.00 sec)

ในแบบสอบถามต่อไปนี้ เราคำนวณ DATE โดยใช้ฟังก์ชันวันที่ที่แตกต่างกันทั้งหมด -

mysql> Select ID, Estb, CURDATE(), YEAR(Estb), MONTH(Estb), DAY(Estb), (RIGHT(CURDATE(),5) < RIGHT(estb,5))As 'Return' FROM Collegedetail;
+------+------------+------------+------------+-------------+-----------+--------+
| ID   | Estb       | CURDATE()  | YEAR(Estb) | MONTH(Estb) | DAY(Estb) | Return |
+------+------------+------------+------------+-------------+-----------+--------+
| 111  | 2010-05-01 | 2017-11-30 | 2010       | 5           | 1         | 0      |
| 130  | 1995-10-25 | 2017-11-30 | 1995       | 10          | 25        | 0      |
| 139  | 1994-09-25 | 2017-11-30 | 1994       | 9           | 25        | 0      |
| 1539 | 2001-07-23 | 2017-11-30 | 2001       | 7           | 23        | 0      |
| 1545 | 2010-07-30 | 2017-11-30 | 2010       | 7           | 30        | 0      |
+------+------------+------------+------------+-------------+-----------+--------+
5 rows in set (0.00 sec)

mysql> Select ID, estb, CURDATE(),((YEAR(CURDATE())-YEAR(estb))-(RIGHT(CURDATE(),5)<RIGHT(estb,5))) AS 'YEARS_OLD' from collegedetail;
+------+------------+------------+-----------+
| ID   | estb       | CURDATE()  | YEARS_OLD |
+------+------------+------------+-----------+
| 111  | 2010-05-01 | 2017-11-30 | 7         |
| 130  | 1995-10-25 | 2017-11-30 | 22        |
| 139  | 1994-09-25 | 2017-11-30 | 23        |
| 1539 | 2001-07-23 | 2017-11-30 | 16        |
| 1545 | 2010-07-30 | 2017-11-30 | 7         |
+------+------------+------------+-----------+
5 rows in set (0.00 sec)