开发者社区 问答 正文

mysql 疑问,求指点

MySQL提供了几个函数,可以用来计算日期,例如,计算年龄或提取日期部分。
要想确定每个宠物有多大,可以计算当前日期的年和出生日期之间的差。如果当前日期的日历年比出生日期早,则减去一年。以下查询显示了每个宠物的出生日期、当前日期和年龄数值的年数字。
`SELECT name, birth, CURDATE(),
(YEAR(CURDATE())-YEAR(birth))
(RIGHT(CURDATE(),5) AS age
FROM pet;
(YEAR(CURDATE())-YEAR(birth))- (RIGHT(CURDATE(),5)请问这一句是什么意思? CURDATE()
RIGHT(CURDATE())什么意思?
5是什么意思?

展开
收起
落地花开啦 2016-02-20 10:55:06 2297 分享 版权
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    (YEAR(CURDATE())-YEAR(birth)) - (RIGHT(CURDATE(),5)<RIGHT(birth,5))
    CURDATE()返回当前时间
    YEAR()返回年份
    RIGHT(str,len)返回str字符串中从末尾数len长度个字符

    (YEAR(CURDATE())-YEAR(birth)) - (RIGHT(CURDATE(),5)<RIGHT(birth,5))
    (当前年份-出生年份)-(当前月日<出生月日)
    (当前月日<出生月日)为真返回1,为假返回0

    当前2012-04-05 出生1988-05-01
    (2012-2000)-(04-05<05-01)= 12-1=11

    2019-07-17 18:45:11
    赞同 展开评论