SQLSTATE[HY000]: General error: 1298 Unknown or incorrect time zone: 'UTC' windows
I am getting this error while setting up a PHP source code in Windows Wamp server.
SQLSTATE[HY000]: General error: 1298 Unknown or incorrect time zone: 'UTC'
Please let me know how to solve.
Thanks.
You have three ways to solve this problem.
Method 1 Install the timezone database
The mysql_tzinfo_to_sql program loads the time zone tables in the mysql database. It is used on systems that have a zoneinfo database (the set of files describing time zones). Examples of such systems are Linux, FreeBSD, Solaris, and OS X. One likely location for these files is the /usr/share/zoneinfo directory (/usr/share/lib/zoneinfo on Solaris). If your system does not have a zoneinfo database, you can use the downloadable package described in Section 11.6, “MySQL Server Time Zone Support”.
mysql_tzinfo_to_sql can be invoked several ways:
shell> mysql_tzinfo_to_sql tz_dir
shell> mysql_tzinfo_to_sql tz_file tz_name
shell> mysql_tzinfo_to_sql --leap tz_file
For the first invocation syntax, pass the zoneinfo directory path name to mysql_tzinfo_to_sql and send the output into the mysql program. For example:
shell> mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root mysql
mysql_tzinfo_to_sql reads your system's time zone files and generates SQL statements from them. mysql processes those statements to load the time zone tables.
The second syntax causes mysql_tzinfo_to_sql to load a single time zone file tz_file that corresponds to a time zone name tz_name:
shell> mysql_tzinfo_to_sql tz_file tz_name | mysql -u root mysql
If your time zone needs to account for leap seconds, invoke mysql_tzinfo_to_sql using the third syntax, which initializes the leap second information. tz_file is the name of your time zone file:
shell> mysql_tzinfo_to_sql --leap tz_file | mysql -u root mysql
After running mysql_tzinfo_to_sql, it is best to restart the server so that it does not continue to use any previously cached time zone data.
source: https://dev.mysql.com/doc/refman/5.7/en/mysql-tzinfo-to-sql.html
Method 2 Update your my.cnf file to use a timezone offset instead
default-time-zone = +0:00
Method 3 Remove or comment out offending statement from your my.cnf file
# default-time-zone = UTC
This will cause it to inherit the timezone from the OS instead.