将年龄转换为当前日期

问题描述 投票:4回答:2

是否有任何PHP函数可以将当前年龄转换为YYYY-MM-DD格式的日期。我以YYYY-MM-DD格式存储了DOB,我想运行SQLite查询:

SELECT FirstName FROM mytable WHERE DOB >= $MinAge AND DOB <= '$MaxAge';

我搜索谷歌转换年龄到日期格式但找不到任何功能,是否有人可以提供帮助?

php sqlite
2个回答
6
投票

是否有任何PHP函数可以将当前年龄转换为日期

不,年龄包含的信息少于约会。一个人有X岁可能有365种可能性,但出生日期可以映射到一个年龄。

换句话说,如果我告诉你我20岁,请你告诉我我的生日,你就不能肯定。但是,如果我告诉你我的生日,你可以肯定地告诉我我的年龄。

由于您的专栏名为DOB,我假设您已存储了出生日期,而不是年龄。在这种情况下,可以获取落在特定年龄范围内的用户。


假设您要查找年龄介于18到50岁之间的所有用户(包括18和50)。

对于今天18岁的用户,他的生日必须是:

  • today - 18 years之前或之上
  • today - 19 years之后

对于今天50岁的用户,他的生日必须是:

  • today - 50 years之前或之上
  • today - 51 years之后

注意,“之前或之后”和“之后”分别只是“<=”和“>”。

那么,如果您想要所有年龄在18到50岁之间的用户怎么办?

你可以采取两个外部界限:

用户的年龄介于18至50之间: qazxsw poi

dob <= (today -18 years) and dob > (today - 51 years)

请注意,如果你计划在1970年之前的日期(52-ish),你应该使用$lower = date('Y-m-d', strtotime('today -18 years')); $upper = date('Y-m-d', strtotime('today -51 years')); $query = "SELECT FirstName FROM users WHERE dob >= '$lower' AND dob < '$upper';"; 而不是date和sttrtotime(我实际上只在实际代码中使用DateTime,但是date / strtotime为更简洁的例子做了准备)。

85年前使用DateTime的一个例子:

DateTime

1
投票

要将当前年龄转换为生日,请使用以下代码:它正确地与我合作

$d = new DateTime('today -85 years');
$s = $d->format('Y-m-d'); //1927-06-03 as of 3 June 2012

检测结果:

function age_To_Birthday($age) {
    $days = (int)($age * 365); //convert age to days

    $date = new DateTime("today -$days day");
    $birthday = $date->format('Y-m-d');
    return $birthday;
}
© www.soinside.com 2019 - 2024. All rights reserved.