我有一个MySQL DATETIME字段,用于保存用户的出生日期。我想使用该日期来显示用户年龄的年龄。
是否有Time核心助手的方法来执行此操作?
另外,为什么当你在Cake中的表单中添加DATETIME字段时,它不允许你选择一个小于1990的日期?
谢谢,
Jonesy
答案 0 :(得分:4)
该函数称为timeAgoInWords
<?php echo $this->Time->timeAgoInWords(
'1975-12-29 13:40',
array(
'end'=>'+150 years'
)
);?>
结束参数意味着显示时间前的单词,直到日期少于150年(至少我还没有听说过150yo人:))))。
目前的结果是:出生:34岁前,9个月,4周
但也要检查API和CookBook作为杰森的建议
答案 1 :(得分:3)
答案 2 :(得分:3)
添加新答案,因为代码会更好地显示。我该怎么做:
你的模型中的就像这样创建virtual field。
var $virtualFields = array(
'age' => "YEAR(NOW())-YEAR(YourModelName.datetimeField)"
);
然后将其用作模型中的普通字段。 :)
答案 3 :(得分:1)
您可以使用标准PHP函数执行计算 - 查看日期部分。我不会告诉你该怎么做,因为你自己会学到很多东西。
我会说你需要小心才能得到准确的结果。 365天并不总是一年,一个月的天数可变。
您可以在Cake表单助手中配置日期选择范围。
答案 4 :(得分:0)
我总是使用这种测试方法:
/*
* @return int age (0 if both timestamps are equal or empty, -1 on invalid dates)
* 2009-03-12 ms
*/
function age($start = null, $end = null, $accuracy = 0) {
$age = 0;
if (empty($start) && empty($end) || $start == $end) {
return 0;
}
if (empty($start)) {
list($yearS, $monthS, $dayS) = explode('-', date(FORMAT_DB_DATE));
} else {
$startDate = $this->fromString($start);
$yearS = date('Y', $startDate);
$monthS = date('m', $startDate);
$dayS = date('d', $startDate);
if (!checkdate($monthS, $dayS, $yearS)) {
return -1;
}
}
if (empty($end)) {
list($yearE, $monthE, $dayE) = explode('-', date(FORMAT_DB_DATE));
} else {
$endDate = $this->fromString($end);
$yearE = date('Y', $endDate);
$monthE = date('m', $endDate);
$dayE = date('d', $endDate);
if (!checkdate($monthE, $dayE, $yearE)) {
return -1;
}
}
$n_tag = $dayE;
$n_monat = $monthE;
$n_jahr = $yearE;
$g_tag = $dayS;
$g_monat = $monthS;
$g_jahr = $yearS;
$g_date = mktime(0,0,0,$g_tag,$g_monat,$g_jahr);
if (($n_monat>$g_monat)||(($n_monat == $g_monat)&&($n_tag>$g_tag))||(($n_monat == $g_monat)&&($n_tag==$g_tag))) {
$age = $n_jahr-$g_jahr; // is correct if one already had his birthday this year
} else {
$age = $n_jahr-$g_jahr-1; // is correct if one didnt have his birthday yet in this year
}
return $age;
}
它可能会被重构 但它适用于闰年和各种各样的东西。所以我从不打扰......
它使用你没有的常数
它只是:define('FORMAT_DB_DATE','Y-m-d');