gpt4 book ai didi

php - 如何更改插入数据库的日期的时区?

转载 作者:行者123 更新时间:2023-11-30 01:37:52 25 4
gpt4 key购买 nike

当我将时间戳插入数据库时​​,该值比本地时间早大约 10 小时。该数据库托管在 Godaddy 的服务器上。

我更改了 php5.ini 文件并添加了 date.timezone = 'Europe/Istanbul'

(默认为 america/phoenix)当我检查 phpinfo();

然后我运行了这段代码:

if (date_default_timezone_get()) {
echo 'date_default_timezone: '. date_default_timezone_get() .'<br />';
}

if (ini_get('date.timezone')) {
echo 'date.timezone: ' . ini_get('date.timezone');
echo date("d/m/y : H:i:s", time());
}

也可以和我本地时间一样

但是当我插入数据时,它会得到 America/Phoenix 时间戳,距离我的本地时间为 -10 小时

这是我的插入代码

$insertSQL = sprintf("INSERT INTO cepbank (username, trans_id, bank, tutar, operator) VALUES ('$username', '$trans_id', '$bank', '$tutar', '$operator')");

这是我的 MySql 表

CREATE TABLE `cepbank` (
`id` int(11) NOT NULL auto_increment,
`username` varchar(11) collate utf8_turkish_ci NOT NULL,
`trans_id` int(11) NOT NULL,
`bank` varchar(11) collate utf8_turkish_ci NOT NULL,
`tutar` decimal(10,2) NOT NULL,
`operator` varchar(32) collate utf8_turkish_ci NOT NULL,
`tarih` timestamp NOT NULL default CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_turkish_ci COMMENT='CepBank Gelen' AUTO_INCREMENT=143 ;

最佳答案

发生这种情况是因为您对tarih 字段使用默认CURRENT_TIMESTAMP。并且它使用未调整的服务器日期。在php中获取调整后的时间戳:

$timestamp = date('Y-m-d H:i:s', time ());

然后将其添加到查询中:

INSERT INTO cepbank 
(tarih, username, trans_id, bank, tutar, operator)
VALUES
('$timestamp','$username', '$trans_id', '$bank', '$tutar', '$operator'

关于php - 如何更改插入数据库的日期的时区?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16613718/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com