什么是正确的格式传递给日期()函数在PHP中,如果我想将结果插入到一个MySQL datetime类型列?
我一直在尝试date('Y-M-D G: I:s'),但每次都只是插入“0000-00-00 00:00:00”。
什么是正确的格式传递给日期()函数在PHP中,如果我想将结果插入到一个MySQL datetime类型列?
我一直在尝试date('Y-M-D G: I:s'),但每次都只是插入“0000-00-00 00:00:00”。
当前回答
这里有一个替代的解决方案:如果在PHP中将日期作为时间戳,那么不用PHP处理它,而是使用FROM_UNIXTIME函数让DB负责转换它。
mysql> insert into a_table values(FROM_UNIXTIME(1231634282));
Query OK, 1 row affected (0.00 sec)
mysql> select * from a_table;
+---------------------+
| a_date |
+---------------------+
| 2009-01-10 18:38:02 |
+---------------------+
其他回答
用PHP格式化MySQL datetime
$date = "'".date('Y-m-d H:i:s', strtotime(str_replace('-', '/', $_POST['date'])))."'";
对已接受答案的一个小补充:如果数据库datetime存储为UTC(我总是这样做),您应该使用gmdate('Y-m-d H: I:s')而不是date("Y-m-d H: I:s")。
或者,如果你更喜欢让MySQL处理所有事情,就像一些答案建议的那样,我会插入MySQL的UTC_TIMESTAMP,结果是一样的。
注:我理解的问题指的是当前时间。
这里有一个替代的解决方案:如果在PHP中将日期作为时间戳,那么不用PHP处理它,而是使用FROM_UNIXTIME函数让DB负责转换它。
mysql> insert into a_table values(FROM_UNIXTIME(1231634282));
Query OK, 1 row affected (0.00 sec)
mysql> select * from a_table;
+---------------------+
| a_date |
+---------------------+
| 2009-01-10 18:38:02 |
+---------------------+
如果不使用时间戳,就没有必要使用PHP中的date()方法。如果dateposting是一个datetime列,你可以像这样插入当前日期:
$db->query("INSERT INTO table (dateposted) VALUES (now())");
$date_old = '23-5-2016 23:15:23';
//Date for database
$date_for_database = date ('Y-m-d H:i:s'", strtotime($date_old));
//Format should be like 'Y-m-d H:i:s'`enter code here`