Как установить часовой пояс MySQL?
На одном сервере, когда я запускаю:
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2009-05-30 16:54:29 |
+---------------------+
1 row in set (0.00 sec)
На другом сервере:
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2009-05-30 20:01:43 |
+---------------------+
1 row in set (0.00 sec)
Ответы
Ответ 1
Я подумал, что это может быть полезно:
Есть три места, где в MySQL может быть установлен часовой пояс:
В файле "my.cnf" в разделе [mysqld]
default-time-zone='+00:00'
@@global.time_zone variable
Чтобы узнать, на какое значение они установлены:
SELECT @@global.time_zone;
Чтобы установить для него значение, используйте один из них:
SET GLOBAL time_zone = '+8:00';
SET GLOBAL time_zone = 'Europe/Helsinki';
SET @@global.time_zone = '+00:00';
(Использование названных часовых поясов, таких как "Европа/Хельсинки", означает, что вы должны правильно заполнить таблицу часовых поясов.)
Имейте в виду, что +02:00
является смещением. Europe/Berlin
- это часовой пояс (который имеет два смещения), а CEST
- это время синхронизации, соответствующее конкретному смещению.
@@session.time_zone variable
SELECT @@session.time_zone;
Чтобы установить его, используйте один из них:
SET time_zone = 'Europe/Helsinki';
SET time_zone = "+00:00";
SET @@session.time_zone = "+00:00";
Оба могут вернуть SYSTEM, что означает, что они используют часовой пояс, указанный в my.cnf.
Для того, чтобы названия часовых поясов работали, вы должны настроить свои информационные таблицы в часовом поясе, которые необходимо заполнить: http://dev.mysql.com/doc/refman/5.1/en/time-zone-support.html. Я также упоминаю, как заполнить эти таблицы в этом ответе.
Чтобы получить текущее смещение часового пояса как TIME
SELECT TIMEDIFF(NOW(), UTC_TIMESTAMP);
Он вернется в 02:00:00, если ваш часовой пояс равен +2: 00.
Чтобы получить текущую временную метку UNIX:
SELECT UNIX_TIMESTAMP();
SELECT UNIX_TIMESTAMP(NOW());
Чтобы получить столбец timestamp как отметку времени UNIX
SELECT UNIX_TIMESTAMP(`timestamp`) FROM `table_name`
Чтобы получить столбец datetime UTC как временную метку UNIX
SELECT UNIX_TIMESTAMP(CONVERT_TZ(`utc_datetime`, '+00:00', @@session.time_zone)) FROM `table_name`
Примечание. Изменение часового пояса не изменит хранимое время datetime или timestamp, но покажет другое время для существующих столбцов временной метки, поскольку они внутренне хранятся в виде временных меток UTC и внешне отображаются в текущем MySQL часовой пояс.
Я сделал чит-коды здесь: Должен ли MySQL установить часовой пояс в UTC?
Ответ 2
Для всех, у кого есть эта проблема:
value="jdbc:mysql://localhost:3306/dbname?serverTimezone=UTC"
Работал для меня. Просто добавьте ?serverTimezone=UTC
в конец.
Ответ 3
Когда вы можете настроить сервер часового пояса для MySQL или PHP:
Запомнить:
-
Изменить систему часовых поясов. Пример для Ubuntu:
$ sudo dpkg-reconfigure tzdata
-
Перезагрузите сервер, или вы можете перезапустить Apache 2 и MySQL:
/etc/init.d/mysql restart
Ответ 4
Чтобы установить его для текущего сеанса, выполните:
SET time_zone = timezonename;
Ответ 5
Просто запустите это на своем сервере MySQL:
SET GLOBAL time_zone = '+8:00';
Где +8: 00 будет вашим часовым поясом.
Ответ 6
Эта работа для меня для местоположения в Индии:
SET GLOBAL time_zone = "Asia/Calcutta";
SET time_zone = "+05:30";
SET @@session.time_zone = "+05:30";
Ответ 7
Вы можете указать часовой пояс по умолчанию сервера при его запуске, см. http://dev.mysql.com/doc/refman/5.1/en/server-options.html и, в частности, параметр --default-time-zone=timezone
. Вы можете проверить глобальные и сеансовые часовые пояса с помощью
SELECT @@global.time_zone, @@session.time_zone;
установить либо или оба с инструкцией SET
, & c; см. http://dev.mysql.com/doc/refman/5.1/en/time-zone-support.html для более подробной информации.
Ответ 8
Имейте в виду, что "Страна/Зона" иногда не работает... Эта проблема не зависит от операционной системы, версии MySQL и аппаратного обеспечения - я встречал ее с FreeBSD 4 и Slackware Linux с 2003 года по сегодняшний день. MySQL с версии 3 до последней версии исходного кода. Это ODD, но это случается. Например:
[email protected]# ls -la /usr/share/zoneinfo/US
total 8
drwxr-xr-x 2 root root 4096 Apr 10 2013 .
drwxr-xr-x 22 root root 4096 Apr 10 2013 ..
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Alaska -> ../SystemV/YST9YDT
lrwxrwxrwx 1 root root 21 Jul 8 22:33 Aleutian -> ../posix/America/Adak
lrwxrwxrwx 1 root root 15 Jul 8 22:33 Arizona -> ../SystemV/MST7
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Central -> ../SystemV/CST6CDT
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Eastern -> ../SystemV/EST5EDT
lrwxrwxrwx 1 root root 37 Jul 8 22:33 East-Indiana -> ../posix/America/Indiana/Indianapolis
lrwxrwxrwx 1 root root 19 Jul 8 22:33 Hawaii -> ../Pacific/Honolulu
lrwxrwxrwx 1 root root 24 Jul 8 22:33 Indiana-Starke -> ../posix/America/Knox_IN
lrwxrwxrwx 1 root root 24 Jul 8 22:33 Michigan -> ../posix/America/Detroit
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Mountain -> ../SystemV/MST7MDT
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Pacific -> ../SystemV/PST8PDT
lrwxrwxrwx 1 root root 18 Jul 8 22:33 Pacific-New -> ../SystemV/PST8PDT
lrwxrwxrwx 1 root root 20 Jul 8 22:33 Samoa -> ../Pacific/Pago_Pago
[email protected]#
И такое утверждение должно работать:
SET time_zone='US/Eastern';
Но у вас есть эта проблема:
Код ошибки: 1298. Неизвестный или неправильный часовой пояс: 'EUS/Eastern'
Взгляните на подпапку в вашей информационной директории зоны и посмотрите АКТУАЛЬНОЕ имя файла для символической ссылки, в данном случае это EST5EDT. Тогда попробуйте это утверждение:
SET time_zone='EST5EDT';
И это на самом деле работает, как и должно! :) Помните об этом трюке; Я не видел, чтобы это было задокументировано в руководствах MySQL и официальной документации. Но чтение соответствующей документации является обязательной вещью: официальная документация по часовому поясу MySQL 5.5 - и не забывайте загружать данные часового пояса на ваш сервер вот так (запустите от имени пользователя root!):
mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root mysql
Трюк номер один - это должно быть сделано именно под пользователем root MySQL. Он может дать сбой или привести к неработающему результату даже от пользователя, который имеет полный доступ к базе данных MySQL - я сам видел сбой.
Ответ 9
Если вы используете PDO:
$offset="+10:00";
$db->exec("SET time_zone='".$offset."';");
Если вы используете MySQLi:
$db->MySQLi->query("SET time_zone='".$offset."';");
Подробнее о форматировании смещения здесь: https://www.sitepoint.com/synchronize-php-mysql-timezone-configuration/
Ответ 10
Древний вопрос с еще одним предложением:
Если вы недавно изменили часовой пояс ОС, например, через:
unlink /etc/localtime
ln -s /etc/usr/share/zoneinfo/US/Eastern /etc/localtime
... MySQL (или MariaDB) не заметит, пока вы не перезапустите службу db:
service mysqld restart
(или)
service mariadb restart
Ответ 11
Если вы используете MySql Workbench, вы можете установить это, открыв представление администратора и выбрав вкладку "Дополнительно". Верхний раздел - "Локализация", а первый флажок должен быть "по умолчанию - зона времени". Установите этот флажок, а затем введите требуемый часовой пояс, перезапустите сервер, и вы должны быть добрым.
Ответ 12
Чтобы установить стандартный часовой пояс на MariaDB, вам нужно перейти в файл 50-server.cnf.
sudo nano /etc/mysql/mariadb.conf.d/50-server.cnf
Затем вы можете ввести следующую запись в разделе MySQL.
default-time-zone='+01:00'
Пример:
#
# These groups are read by MariaDB server.
# Use it for options that only the server (but not clients) should see
#
# See the examples of server my.cnf files in /usr/share/mysql/
#
# this is read by the standalone daemon and embedded servers
[server]
# this is only for the mysqld standalone daemon
[mysqld]
#
# * Basic Settings
#
user = mysql
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
port = 3306
basedir = /usr
datadir = /var/lib/mysql
tmpdir = /tmp
lc-messages-dir = /usr/share/mysql
skip-external-locking
### Default timezone ###
default-time-zone='+01:00'
# Instead of skip-networking the default is now to listen only on
# localhost which is more compatible and is not less secure.
Изменение должно быть сделано через файл конфигурации, в противном случае сервер MariaDB сбросит таблицы mysql после перезапуска!
Ответ 13
Сначала выясните, какой часовой пояс вы можете запросить
SHOW VARIABLES LIKE '%time_zone%';
Ваш вывод должен быть примерно таким:
**Variable_name** **Value**
system_time_zone CDT
time_zone SYSTEM
Затем, если вы хотите подтвердить, что вы находитесь в каком-то часовом поясе, например, CDT, а не в EST, вы можете проверить, в какое время, по вашему мнению, находится ваша машина,
SELECT NOW();
Если это не то время, которое вы хотите, вам нужно изменить его... все, что вам нужно сделать, это SET time_zone = timezone_name
. Убедитесь, что он в формате " Continent/City
.
Если вы находитесь на общем сервере, потому что у вас есть хостинг, пожалуйста, обратитесь к этим ответам относительно изменения файла php.ini или файла .htaccess.
Ответ 14
В Windows (IIS) для установки SET GLOBAL time_zone = 'Europe/Helsinki' (или чего-либо другого) сначала необходимо заполнить таблицы описания часового пояса MySQL.
Я скачал их по этой ссылке https://dev.mysql.com/downloads/timezones.html
После запуска загруженного SQL-запроса я смог установить глобальный часовой пояс и решить проблему, в которой находился SELECT NOW(); возвращал GMT, а не BST.
Ответ 15
Это вопрос 10 лет, но в любом случае вот что сработало для меня. Я использую MySQL 8.0 с Hibernate 5 и SpringBoot 4.
Я попробовал приведенный выше ответ, но у меня ничего не вышло, у меня сработало следующее:
db.url=jdbc:mysql://localhost:3306/testdb?useSSL=false&serverTimezone=Europe/Warsaw
Ответ 16
Вы должны настроить часовой пояс своего местоположения. Чтобы следовать ниже, процесс
Откройте MSQLWorkbench, напишите простую команду sql, как это;
select now();
А также ваш URL мог бы быть таким;
url = "jdbc:mysql://localhost:3306/your_database_name?serverTimezone=UTC";