5

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

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

我搜索了谷歌将年龄转换为日期格式,但找不到任何功能,有人可以帮忙吗?

4

2 回答 2

7

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

不,年龄包含的信息少于日期。一个人有 365 种可能成为 X 岁,但出生日期恰好对应一个年龄。

换句话说,如果我告诉你我 20 岁,并要求你告诉我我的生日,你不能确定。但是,如果我告诉你我的生日,那么你可以肯定地告诉我我的年龄。

由于您的列名为 DOB,因此我假设您存储了出生日期,而不是年龄。在这种情况下,可以获取某个年龄段的用户。


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

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

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

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

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

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

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

您可以只采用两个外部边界:

用户的年龄在 18 到 50 岁之间,如果:
dob <= (today -18 years) and dob > (today - 51 years)

$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';";

请注意,如果您计划在 1970 年(52 岁左右)之前的日期,您可能应该使用DateTime而不是 date 和 sttrtotime(我实际上只在实际代码中使用 DateTime,但 date/strtotime 用于更简短的示例)。

85 年前的 DateTime 示例:

$d = new DateTime('today -85 years');
$s = $d->format('Y-m-d'); //1927-06-03 as of 3 June 2012
于 2012-06-03T07:22:08.117 回答
2

要将当前年龄转换为生日,请使用以下代码:它与我一起正常工作

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;
}

测试结果:

echo age_To_Birthday(1)     . "<br>"; //2017-09-09
echo age_To_Birthday(5)     . "<br>"; //2013-09-10
echo age_To_Birthday(1.5)   . "<br>"; //2017-03-11
echo age_To_Birthday(1.25)  . "<br>"; //2017-06-10
echo age_To_Birthday(0.25)  . "<br>"; //2018-06-10
echo age_To_Birthday(0.5)   . "<br>"; //2018-03-11
echo age_To_Birthday(0.75)  . "<br>"; //2017-12-10
于 2018-09-09T03:54:58.633 回答