6

如何将 MYSQL TIMEZONE 更改为 GMT 格式,如 PHP 中的此函数:/ SET GMT TIMEZONE /date_default_timezone_set('Etc/GMT');

我的数据库类在这里:

class DB {
    private static $instance;
    private $MySQLi;

    private function __construct(array $dbOptions){

        $this->MySQLi = @ new mysqli(   $dbOptions['db_host'],
                                        $dbOptions['db_user'],
                                        $dbOptions['db_pass'],
                                        $dbOptions['db_name'] );

        if (mysqli_connect_errno()) {
            throw new Exception('Database error.');
        }

        $this->MySQLi->set_charset("utf8");
    }

    public static function init(array $dbOptions){
        if(self::$instance instanceof self){
            return false;
        }

        self::$instance = new self($dbOptions);
    }

    public static function getMySQLiObject(){
        return self::$instance->MySQLi;
    }

    public static function query($q){
        return self::$instance->MySQLi->query($q);
    }

    public static function prepare($q){
        return self::$instance->MySQLi->prepare($q);
    }

    public static function esc($str){
        return self::$instance->MySQLi->real_escape_string(htmlspecialchars($str));
    }

}

我在其他文件中的查询是这样的:

DB::query('UPDATE `calendar_data` SET `data` = "'.DB::esc(json_encode($array)).'", `upcoming_time` = "'.date('Y-m-d H:i:s', $upcoming).'", `time_now` = NOW() WHERE `id` = "1"');

我应该在哪里将查询插入到类中以运行一次?

谢谢!

$this->MySQLi->set_charset("utf8");
$this->MySQLi->query("SET timezone = 'GMT'");
  • 不工作。如果我使用 NOW(),则插入服务器时间 (GMT-4)。哪里有问题???
4

4 回答 4

10

Try the following:

$this->MySQLi->query("SET time_zone = '+0:00'");

Using named timezones will only work if the time zone information tables in the MySQL database have been created and populated.

于 2012-09-06T09:57:16.337 回答
5

写完之后:

$this->MySQLi->set_charset("utf8");

还要写这个:

$this->MySQLi->query("SET timezone = 'GMT'");

此时区设置将应用于该连接上发送的所有未来查询。

此外,请确保您已在 mysql 数据库中设置区域表。

http://dev.mysql.com/doc/refman/5.5/en/mysql-tzinfo-to-sql.html

于 2012-09-06T09:26:10.270 回答
4

从手册;

每个连接时区。每个连接的客户端都有自己的时区设置,由会话 time_zone 变量给出。最初,会话变量从全局 time_zone 变量中获取其值,但客户端可以使用以下语句更改自己的时区:

mysql> SET time_zone = timezone;

所以一定是这样的;

$this->MySQLi->query("SET time_zone = 'GMT'");

http://dev.mysql.com/doc/refman/5.5/en//time-zone-support.html
http://dev.mysql.com/doc/refman/5.5/en//server-system-variables .html#sysvar_time_zone

于 2013-02-06T13:38:31.230 回答
2

MySQL 具有广泛的时区支持。您可以在服务器级别、每个连接甚至每个查询上设置它。我认为在 __construct 中执行 'SET time_zone = xxx' 对你来说已经足够了。

于 2012-09-06T09:26:27.617 回答