- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我需要更改单个数据库的时区,这可能吗?
我知道我们可以在 WHM 中更改时区(我们正在使用来自 hostgator 的专用服务器),但是在服务器上运行的大量遗留软件中有很多 +6 小时的编码(即服务器时区是CST,我们想要 GMT 时间,所以以前的开发人员在代码中手动更改日期/时间 - 糟糕!)。
我现在正在开发一个新软件,并希望在 GMT 中使用它,我知道我可以使用 date_default_timezone_set('GMT') 但这不会解决日期时间列设置为 CURRENT_TIMESTAMP 的 MySQL 插入,因为它会插入@CST 时区。
最佳答案
不可以,无法更改 MySQL 实例中单个数据库的时区。
我们可以通过查询检索服务器和客户端的 time_zone
设置,如下所示:
SELECT @@global.time_zone, @@session.time_zone;
我们还可以更改 session 的客户端时区,或更改整个 MySQL 实例的时区。
但我们需要敏锐地意识到这一变化对现有客户端连接的影响,以及实例中已存储的 DATETIME
和 TIMESTAMP
值将如何被解释。
要在 MySQL 实例启动时设置服务器时区,我们可以修改 /etc/my.cnf
文件(或读取 mysql 实例初始化参数的任何地方),在 下[mysqld]
部分:
[mysqld]
default-time-zone='+00:00'
-- 或--
也可以(不太理想)将 --default_time_zone='+00:00'
选项添加到 mysqld_safe
注意:更改 MySQL 服务器上的时区设置不会更改存储在现有 DATETIME 或 TIMESTAMP 列中的值,但是因为它确实有效地更改了解释这些存储值的上下文,所以它看起来所有的值都被改变了。 (08:00 被认为是 CST 上午 8 点,服务器的时区从 CST 更改为 GMT,同样的“08:00”现在将被视为 GMT 上午 8 点,实际上是 CST 凌晨 2 点。
另请记住,TIMESTAMP 列始终以 UTC 格式存储,而 DATETIME 列没有时区。 http://dev.mysql.com/doc/refman/5.5/en/datetime.html
每个客户端 session 都可以更改自己 session 的时区设置:
SET time_zone='-06:00';
但这并没有真正“解决”时区转换问题,它只是转移了转换问题。
应用层处理时区转换本身并没有什么“坏”之处;有时,这是最好的处理方式。它只需要正确和一致地完成。
(您所描述的设置的奇怪之处在于,应用程序正在存储 DATETIME 值,就好像 MySQL 服务器时区设置为 GMT,但 MySQL 服务器时区设置为其他设置。)
关于mysql - 将 MySQL 数据库时区设置为 GMT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13916747/
在 /usr/share/lib/zoneinfo 下 我可以看到以下 4 种不同类型的 GMT 信息 GMT GMT+0 GMT-0 GMT0 这 4 种 GMT 区域时间之间有什么区别吗?如果是这
我有这样的输入格式,我需要将其转换为 GMT 格式: $input = array( "gmt" => "+7", "datetime" => "2017-
我尝试了以下代码,应该允许我将时间传递作为参数转换为一个多一小时 (GMT+1) 的字符串。 但我总是得到与我对象时间相同的时间 public static String getFormattedTi
为什么 GMT-0400 在 1989 年之前转变为 GMT-0500? > new Date('1989-04-02T23:01:14.52Z') Sun Apr 02 1989 19:01:14
我从服务器获取日期字符串及其 GMT+2 我认为无法转换为印度 GMT 5:30 格式 这是服务器日期字符串 2017-01-11T05:08:15.157Z 我想要印度时间格式的这个我已经尝试了下面
我每分钟运行一个任务,我想打印出当前 GMT 时间和 9PM GMT 之间的差异,我希望它一直运行,所以一旦到达 9PM GMT,它就会重置为 24 小时所以它正在寻找第二天晚上 9 点(格林威治标准
在这方面遇到了困难,尝试了所有这些不同的日期函数,但不知道如何确定地做到这一点。 最佳答案 您可以使用calendar.timegm来获取自纪元以来的秒数。时间元组是必需的参数,time.strpti
我知道有多种方法可以将日期时间转换为 Unix 时间戳。 但问题是当我们将 GMT 的日期时间值转换为 Unix 时间戳时,它会根据我本地时区的值显示时间戳的值,即 Asia/Kolkata 例如:G
当我将 user_login_date 存储到数据库中时,它是 GMT +5:30,但我的数据库设置为 GMT 0:00 用户在 12:00:00 登录但数据库将该日期存储为 07:30:00 的示例
当我使用“日期”命令时,我们的服务器提供 GMT 时间。但是我现在的时间应该是GMT+8。如何将当前时间显示为 GMT+8?提前致谢。 最佳答案 将这样的一行添加到您的 .profile 文件中,然后
我正在使用此代码获取 android 设备的 timezone TimeZone tz = TimeZone.getDefault(); String current_Time_Zone = (Tim
我也想要 GMT 字符串的时间。 但我无法得到它。 DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd/hh-mm"); dateForm
我也是 MVC3 和 C# 的新手。我将使用 C# 通过 MVC3 创建一个测试博客站点。用户可以在哪里写帖子,所以我需要存储用户帖子日期时间,并想在自己的本地时间显示每个其他用户的日期时间。对于这种
我在使用 PHP DateTime 将 GMT -8 时区 (PST) 接收的日期转换为 GMT -7 (PDT) 时区的人类可读格式时遇到困难。 这是一个例子: $tz = new DateTime
例如,我想解析下面的字符串: Tue Sep 28 18:02:24 GMT+08:00 2010 我使用 SimpleDateFormat 的模式: new SimpleDateFormat("EE
我正在尝试使用 html 输入中的信息查询数据库。日期的格式为: Date {Sun Jun 03 2012 00:00:00 GMT+0100 (GMT Daylight Time)} 在我
我有一种情况,我收到以下格式的字符串形式的日期。 “2014 年 1 月 13 日星期一 00:00:00 GMT+0000(GMT 标准时间)” 我需要在 c# 中将其转换为以下格式(日期/字符串)
我能够从完整的字符串名称“Australia/Brisbane”中获取 Java 中的时区对象 TimeZone tz = TimeZone.getTimeZone("Australia/Brisba
我能够从完整的字符串名称“Australia/Brisbane”中获取 Java 中的时区对象 TimeZone tz = TimeZone.getTimeZone("Australia/Brisba
我有这些数据可供使用: Timezone of local time as integer: 8.75 (which is UTC+8.75) 1) 2012-09-04 03:15:03 2) 20
我是一名优秀的程序员,十分优秀!