php时间问题?mysql数据库的时间格式(Y-M-D H:I:S) 在PHP页面想这样显示(Y-M-D) ('.$rows['ndate'].')

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php时间问题?mysql数据库的时间格式(Y-M-D H:I:S) 在PHP页面想这样显示(Y-M-D) ('.$rows['ndate'].')相关的知识,希望对你有一定的参考价值。

ndate是这(Y-M-D H:I:S)格式,怎么改成(Y-M-D)格式
<?php
include("connect.php");
$SQLselect="select ndate, nid, ntitle from news order by ndate desc";
$result=mysql_query($SQLselect);
while ($rows=mysql_fetch_assoc($result))

echo'<li><a href="news.php?nid='.$rows['nid'].'">'.$rows['ntitle'].'</a> <span>('.$rows['ndate'].')</span></li>';

?>
('.$rows['ndate'].')就这个显示出来是(Y-M-D H:I:S)格式,怎么改成(Y-M-D)格式。

1、首先在电脑上创建一个index.php文件,编辑index.php。

2、然后输入获取当天零点的时间戳,输入代码$today = strtotime(date("Y-m-d"),time());$time = strtotime($today);//获取到echo $time."<br />";//输出。

3、获取当天24点的时间戳$todayEnd = $today+60*60*24;//家一天的时间echo $time = strtotime($todayEnd)."<br />";//输出。

4、获取前一天时间echo date("Y-m-d H:i:s",strtotime("-1 days"));。

5、以上即时间戳和前一天时间的获取。主要是对date()和strtotime()函数的灵活使用,就可以了。

参考技术A 参考一下看看
PHP的日期时间函数date()

1,年-月-日
echo date('Y-m-j');
2007-02-6

echo date('y-n-j');
07-2-6

大写Y表示年四位数字,而小写y表示年的两位数字;
小写m表示月份的数字(带前导),而小写n则表示不带前导的月份数字。

echo date('Y-M-j');
2007-Feb-6

echo date('Y-m-d');
2007-02-06

大写M表示月份的3个缩写字符,而小写m则表示月份的数字(带前导0);
没有大写的J,只有小写j表示月份的日期,无前导o;若需要月份带前导则使用小写d。

echo date('Y-M-j');
2007-Feb-6

echo date('Y-F-jS');
2007-February-6th

大写M表示月份的3个缩写字符,而大写F表示月份的英文全写。(没有小写f)
大写S表示日期的后缀,比如“st”、“nd”、“rd”和“th”,具体看日期数字为何。

小结:
表示年可以用大写的Y和小写y;
表示月可以用大写F、大写M、小写m和小写n(分别表示字符和数字的两种方式);
表示日可以用小写d和小写j,大写S表示日期的后缀。

2,时:分:秒

默认情况下,PHP解释显示的时间为“格林威治标准时间”,与我们本地的时间相差8个小时。

echo date('g:i:s a');
5:56:57 am

echo date('h:i:s A');
05:56:57 AM

小写g表示12小时制,无前导0,而小写h则表示有前导0的12小时制。
当使用12小时制时需要表明上下午,小写a表示小写的“am”和“pm”,大写A表示大写的“AM”和“PM”。

echo date('G:i:s');
14:02:26

大写G表示24小时制的小时数,但是不带前导的;使用大写的H表示带前导的24小时制小时数

小结:
字母g表示小时不带前导,字母h表示小时带前导;
小写g、h表示12小时制,大写G、H表示24小时制。

3,闰年、星期、天

echo date('L');
今年是否闰年:0

echo date('l');
今天是:Tuesday

echo date('D');
今天是:Tue

大写L表示判断今年是否闰年,布尔值,为真返回1,否则为0;
小写l表示当天是星期几的英文全写(Tuesday);
而使用大写D表示星期几的3个字符缩写(Tue)。

echo date('w');
今天星期:2

echo date('W');
本周是全年中的第 06 周

小写w表示星期几,数字形式表示
大写W表示一年中的星期数

echo date('t');
本月是 28 天

echo date('z');
今天是今年的第 36 天

小写t表示当前月份又多少天
小写z表示今天是本年中第几天

4,其他

echo date('T');
UTC
大写T表示服务器的时间区域设置

echo date('I');
0
大写I表示判断当前是否为夏令时,为真返回1,否则为0

echo date('U');
1170769424
大写U表示从1970年1月1日到现在的总秒数,就是Unix时间纪元的UNIX时间戳。

echo date('c');
2007-02-06T14:24:43+00:00
小写c表示ISO8601日期,日期格式为YYYY-MM-DD,用字母T来间隔日期和时间,时间格式为HH:MM:SS,时区使用格林威治标准时间(GMT)的偏差来表示。

echo date('r');
Tue, 06 Feb 2007 14:25:52 +0000
小写r表示RFC822日期。

小小的date()函数就显示出了PHP的强大功能和迷人魅力,再比较下ASP,呵呵。
checkdate($month,$date,$year)

如果应用的值构成一个有效日期,则该函数返回为真。例如,对于错误日期2005年2月31日,此函数返回为假。

在日期用于计算或保存在数据库中之前,可用此函数检查日期并使日期生效。

<?php
// returns false
echo checkdate(2,30,2005) ? "valid" : "invalid";
// returns true
echo checkdate(4,6,2010) ? "valid" : "invalid";
?>

getdate($ts)

在没有自变量的情况下,该函数以结合数组的方式返回当前日期与时间。数组中的每个元素代表日期/时间值中的一个特定组成部分。可向函数提交可选的时间标签自变量,以获得与时间标签对应的日期/时间值。

应用此函数来获得一系列离散的,容易分离的日期/时间值。

<?php
// get date as associative array
$arr = getdate();
echo "Date is " . $arr['mday'] . " " . $arr['weekday'] . " " . $arr['year'];
echo "Time is " . $arr['hours'] . ":" . $arr['minutes'];
?>

mktime($hour, $minute, $second, $month, $day, $year)

此函数的作用与getdate()的作用相反:它由一系列的日期与时间值生成一个UNIX时间标签(GMT时间1970年1月1日到现在消逝的秒数)。不用自变量时,它生成当前时间的UNIX时间标签。

用此函数获得即时时间的UNIX时间标签。这种时间标签通常用于许多数据库与程序语言中。

<?php
// returns timestamp for 13:15:23 7-Jun-2006
echo mktime(13,15,23,6,7,2006);
?>

date($format, $ts)

此函数将UNIX时间标签格式化成一个可人为阅读的日期字符串。它是PHP日期/时间API中功能最为强大的函数,可用在一系列的修正值中,将整数时间标签转变为所需的字符串格式。

为显示格式化时间或日期时,应用此函数。

<?php
// format current date
// returns "13-Sep-2005 01:16 PM"
echo date("d-M-Y h:i A", mktime());
?>

strtotime($str)

此函数将可人为阅读的英文日期/时间字符串转换成UNIX时间标签。

应用此函数将非标准化的日期/时间字符串转换成标准、兼容的UNIX时间标签。

<?php
// returns 13-Sep-05
echo date("d-M-y", strtotime("today"));
// returns 14-Sep-05
echo date("d-M-y", strtotime("tomorrow"));
// returns 16-Sep-05
echo date("d-M-y", strtotime("today +3 days"));
?>

strftime($format,$ts)

如前面的setlocale()函数定义的那样,此函数将UNIX时间标签格式化成适用于当前环境的日期字符串。

应用此函数建立与当前环境兼容的日期字符串。

<?php
// set locale to France (on Windows)
setlocale(LC_TIME, "fra_fra");

// format month/day names
// as per locale setting
// returns "septembre" and "mardi"

echo strftime("Month: %B ");
echo strftime("Day: %A ");
?>

microtime()

如前面的setlocale()函数定义的那样,此函数将UNIX时间标签格式化成适用于当前环境的日期字符串。

应用此函数建立与当前环境兼容的日期字符串。

<?php
// get starting value
$start = microtime();

// run some code
for ($x=0; $x<1000; $x++)
$null = $x * $x;


// get ending value
$end = microtime();

// calculate time taken for code execution
echo "Elapsed time: " . ($end - $start) ." sec";
?>

gmmktime($hour, $minute, $second, $month, $day, $year)

此函数由一系列用GMT时间表示的日期与时间值生成一个UNIX时间标签。不用自变量时,它生成一个当前GMT即时时间的UNIX时间标签。

用此函数来获得GMT即时时间的UNIX时间标签。

<?php
// returns timestamp for 12:25:23 9-Jul-2006
echo gmmktime(12,25,23,7,9,2006);
?>

gmdate($format, $ts)

此函数将UNIX时间标签格式化成可人为阅读的日期字符串。此日期字符串以GMT(非当地时间)表示。

用GMT表示时间标签时应用此函数。

<?php
// format current date into GMT
// returns "13-Sep-2005 08:32 AM"
echo gmdate("d-M-Y h:i A", mktime());
?>

date_default_timezone_set($tz)、date_default_timezone_get()

此函数此后所有的日期/时间函数调用设定并恢复默认的时区。

注:此函数仅在PHP 5.1+中有效。

此函数是一个方便的捷径,可为以后的时间操作设定时区。

<?php
// set timezone to UTC
date_default_timezone_set('UTC');
?>

<?php
//今天
$today = date("Y-m-d");
//昨天
$yesterday = date("Y-m-d", strtotime(date("Y-m-d"))-86400);
//上周
$lastweek_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1-7,date("Y")));
$lastweek_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7-7,date("Y")));
//本周
$thisweek_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1,date("Y")));
$thisweek_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7,date("Y")));
//上月
$lastmonth_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m")-1,1,date("Y")));
$lastmonth_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m") ,0,date("Y")));
//本月
$thismonth_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),1,date("Y")));
$thismonth_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("t"),date("Y")));
//本季度未最后一月天数
$getMonthDays = date("t",mktime(0, 0 , 0,date('n')+(date('n')-1)%3,1,date("Y")));
//本季度/
$thisquarter_start = date('Y-m-d H:i:s', mktime(0, 0, 0,date('n')-(date('n')-1)%3,1,date('Y')));
$thisquarter_end = date('Y-m-d H:i:s', mktime(23,59,59,date('n')+(date('n')-1)%3,$getMonthDays,date('Y')));
?>本回答被提问者和网友采纳
参考技术B 不知道你的那个ndate是什么格式?试试strftime('%Y-%m-%d', strtotime($rows['ndate']))。 参考技术C 格式化呗,输出看看
echo date('Y-m-d',strtotime($rows['ndate']));
参考技术D echo date('Y-m-d H:i:s',$row['ndate']);

设置 PHP 日期时间格式

【中文标题】设置 PHP 日期时间格式【英文标题】:Setting PHP date time format 【发布时间】:2015-01-13 06:21:33 【问题描述】:

我在 MySQL 表中有一个类型为“datetime”的列。 如何从 php 中获取具有格式的当前日期和时间的值 - 例如:“2014-11-09 15:06:51”并设置为变量?

谢谢。

【问题讨论】:

NOW() function in PHP的可能重复 【参考方案1】:

查看PHP documentation 以获得更多说明。

$DateTime = date('Y-m-d H:i:s');

Ref

【讨论】:

【参考方案2】:

你可以使用MySql的CURDATE()。无需为此使用php。

INSERT INTO  `db`.`data1` (
`id` ,
`date`
)
VALUES (
'2', CURDATE()
)

查看更多文档http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html#function_curdate

【讨论】:

【参考方案3】:

如果你在课堂上这样做,你可以使用我的 DateTime getter 和 setter。假设 $this-&gt;Date 是一个 php DateTime object 并且您正在使用带有 DATETIME 列的 mysql。

这是使用它的样子:

$this->setDate($whatever_date); // give it a timestamp, mysql DATETIME, or anything that can be read by strtotime()

// Need to put the date into mysql? Use this:
$this->getDate('mysql');

// Need to get the date so a person can read it? 
$this->getDate('human');

// want it as a timestamp?
$this->getDate('unix');

方法如下:

// accepts 'human', 'mysql', 'unix', or custom date() string
function getDate($format='human')

    if(get_class($this->Date)!='DateTime') return FALSE;


    try

        switch ($format) 
            case 'human':
                return $this->Date->format('M j, Y g:i a'); // Show date and time
                // return $this->Date->format('M j, Y'); // Just the date
                break;

            case 'mysql':
                return $this->Date->format('Y-m-d H:i:s');
                break;

            case 'unix':
                return $this->Date->format('U'); // may return a negative number for old dates
                break;

            default:
                return $this->Date->format($format);
                break;
        

     catch (Exception $e)
        throw new Exception('Can not use that format for getting DateTime');
        return FALSE;
    


// Sets as a DateTime object - accepts either a timestamp or a date() string
function setDate($date)
    try

        if(is_numeric($date) && (int)$date==$date) // timestamp
            $this->Date = new DateTime(date('F j, Y, g:i a', $date));
         else 
            $this->Date = new DateTime($date);
        


     catch (Exception $e)
        throw new Exception('Can not set the given value ('.$date.') as DateTime');
        return FALSE;
    
    return TRUE;

如果您不使用类,您可能希望将它们组合成一个函数,该函数采用您拥有的格式并返回您需要的格式。

【讨论】:

以上是关于php时间问题?mysql数据库的时间格式(Y-M-D H:I:S) 在PHP页面想这样显示(Y-M-D) ('.$rows['ndate'].')的主要内容,如果未能解决你的问题,请参考以下文章

关于时间显示的问题(php)

mysql 时间戳的转换

PHP bug strtotime

php取出mysql表单数据为时间戳,怎么转换成时间格式

通过 PHP cUrl 创建 DHL 发货标签不起作用

php的问题。我用的是mysql,若只显示今年的数据,表里时间格式是0000-00-00,sql语句该怎么写?