2003-05-29 23:47:31 +02:00
#!/bin/sh
2003-06-15 22:24:37 +02:00
# Copyright (C) 1997-2003 MySQL AB
2003-05-29 23:47:31 +02:00
# For a more info consult the file COPYRIGHT distributed with this file
# This script writes on stdout SQL commands to generate all not
# existing MySQL system tables. It also replaces the help tables with
# new context from the manual (from fill_help_tables.sql).
# $1 - "test" or "real" or "verbose" variant of database
# $2 - path to mysql-database directory
# $3 - hostname
# $4 - windows option
2003-06-15 22:24:37 +02:00
if test " $1 " = ""
2003-05-29 23:47:31 +02:00
then
echo "
This script writes on stdout SQL commands to generate all not
existing MySQL system tables. It also replaces the help tables with
new context from the manual ( from fill_help_tables.sql) .
Usage:
2003-06-15 22:24:37 +02:00
mysql_create_system_tables [ test| verbose| real] <path to mysql-database directory> <hostname> <windows option>
"
exit
2003-05-29 23:47:31 +02:00
fi
mdata = $2
hostname = $3
windows = $4
# Initialize variables
c_d = "" i_d = ""
c_h = "" i_h = ""
c_u = "" i_u = ""
c_f = "" i_f = ""
c_t = "" c_c = ""
c_ht = ""
c_hc = ""
c_hr = ""
c_hk = ""
i_ht = ""
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
c_tzn = "" c_tz = "" c_tzt = "" c_tztt = "" c_tzls = ""
i_tzn = "" i_tz = "" i_tzt = "" i_tztt = "" i_tzls = ""
2003-05-29 23:47:31 +02:00
# Check for old tables
if test ! -f $mdata /db.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing db table" 1>& 2;
fi
# mysqld --bootstrap wants one command/line
c_d = " $c_d CREATE TABLE db ( "
c_d = " $c_d Host char(60) binary DEFAULT '' NOT NULL, "
c_d = " $c_d Db char(64) binary DEFAULT '' NOT NULL, "
c_d = " $c_d User char(16) binary DEFAULT '' NOT NULL, "
c_d = " $c_d Select_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Update_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Create_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d References_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Index_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_d = " $c_d PRIMARY KEY Host (Host,Db,User), "
c_d = " $c_d KEY User (User) "
c_d = " $c_d ) "
c_d = " $c_d comment='Database privileges'; "
i_d = " INSERT INTO db VALUES ('%','test','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y');
INSERT INTO db VALUES ( '%' ,'test\_%' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'N' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ) ; "
fi
if test ! -f $mdata /host.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing host table" 1>& 2;
fi
c_h = " $c_h CREATE TABLE host ( "
c_h = " $c_h Host char(60) binary DEFAULT '' NOT NULL, "
c_h = " $c_h Db char(64) binary DEFAULT '' NOT NULL, "
c_h = " $c_h Select_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Update_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Create_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h References_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Index_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_h = " $c_h PRIMARY KEY Host (Host,Db) "
c_h = " $c_h ) "
c_h = " $c_h comment='Host privileges; Merged with database privileges'; "
fi
if test ! -f $mdata /user.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing user table" 1>& 2;
fi
c_u = " $c_u CREATE TABLE user ( "
c_u = " $c_u Host char(60) binary DEFAULT '' NOT NULL, "
c_u = " $c_u User char(16) binary DEFAULT '' NOT NULL, "
2003-07-01 21:40:59 +02:00
c_u = " $c_u Password char(41) binary DEFAULT '' NOT NULL, "
2003-05-29 23:47:31 +02:00
c_u = " $c_u Select_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Insert_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Update_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Delete_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Create_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Drop_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Reload_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Shutdown_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Process_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u File_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Grant_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u References_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Index_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Alter_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Show_db_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Super_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Create_tmp_table_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Lock_tables_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Execute_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Repl_slave_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u Repl_client_priv enum('N','Y') DEFAULT 'N' NOT NULL, "
c_u = " $c_u ssl_type enum('','ANY','X509', 'SPECIFIED') DEFAULT '' NOT NULL, "
c_u = " $c_u ssl_cipher BLOB NOT NULL, "
c_u = " $c_u x509_issuer BLOB NOT NULL, "
c_u = " $c_u x509_subject BLOB NOT NULL, "
c_u = " $c_u max_questions int(11) unsigned DEFAULT 0 NOT NULL, "
c_u = " $c_u max_updates int(11) unsigned DEFAULT 0 NOT NULL, "
c_u = " $c_u max_connections int(11) unsigned DEFAULT 0 NOT NULL, "
c_u = " $c_u PRIMARY KEY Host (Host,User) "
c_u = " $c_u ) "
c_u = " $c_u comment='Users and global privileges'; "
2003-06-15 22:24:37 +02:00
if test " $1 " = "test"
2003-05-29 23:47:31 +02:00
then
i_u = " INSERT INTO user VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0);
INSERT INTO user VALUES ( '$hostname' ,'root' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'' ,'' ,'' ,'' ,0,0,0) ;
2003-06-26 06:39:23 +02:00
REPLACE INTO user VALUES ( '127.0.0.1' ,'root' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'' ,'' ,'' ,'' ,0,0,0) ;
2003-05-29 23:47:31 +02:00
INSERT INTO user ( host,user) values ( 'localhost' ,'' ) ;
INSERT INTO user ( host,user) values ( '$hostname' ,'' ) ; "
else
2003-06-24 11:10:35 +02:00
i_u = "INSERT INTO user VALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0);"
2003-10-06 21:56:34 +02:00
if test " $windows " = "0"
2003-05-29 23:47:31 +02:00
then
2004-06-25 17:49:36 +02:00
i_u = " $i_u
2003-05-29 23:47:31 +02:00
INSERT INTO user VALUES ( '$hostname' ,'root' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'' ,'' ,'' ,'' ,0,0,0) ;
2003-06-24 12:55:39 +02:00
INSERT INTO user ( host,user) values ( '$hostname' ,'' ) ;
INSERT INTO user ( host,user) values ( 'localhost' ,'' ) ; "
2003-06-24 11:10:35 +02:00
else
2004-06-25 17:49:36 +02:00
i_u = " $i_u
2004-06-26 04:11:46 +02:00
INSERT INTO user VALUES ( '%' ,'root' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'' ,'' ,'' ,'' ,0,0,0) ;
INSERT INTO user VALUES ( 'localhost' ,'' ,'' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'Y' ,'' ,'' ,'' ,'' ,0,0,0) ;
INSERT INTO user VALUES ( '%' ,'' ,'' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'N' ,'' ,'' ,'' ,'' ,0,0,0) ; "
2003-06-24 11:10:35 +02:00
fi
2003-05-29 23:47:31 +02:00
fi
fi
if test ! -f $mdata /func.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing func table" 1>& 2;
fi
c_f = " $c_f CREATE TABLE func ( "
c_f = " $c_f name char(64) binary DEFAULT '' NOT NULL, "
c_f = " $c_f ret tinyint(1) DEFAULT '0' NOT NULL, "
c_f = " $c_f dl char(128) DEFAULT '' NOT NULL, "
c_f = " $c_f type enum ('function','aggregate') NOT NULL, "
c_f = " $c_f PRIMARY KEY (name) "
c_f = " $c_f ) "
c_f = " $c_f comment='User defined functions'; "
fi
if test ! -f $mdata /tables_priv.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing tables_priv table" 1>& 2;
fi
c_t = " $c_t CREATE TABLE tables_priv ( "
c_t = " $c_t Host char(60) binary DEFAULT '' NOT NULL, "
c_t = " $c_t Db char(64) binary DEFAULT '' NOT NULL, "
c_t = " $c_t User char(16) binary DEFAULT '' NOT NULL, "
2004-03-19 17:33:38 +01:00
c_t = " $c_t Table_name char(64) binary DEFAULT '' NOT NULL, "
2003-05-29 23:47:31 +02:00
c_t = " $c_t Grantor char(77) DEFAULT '' NOT NULL, "
c_t = " $c_t Timestamp timestamp(14), "
c_t = " $c_t Table_priv set('Select','Insert','Update','Delete','Create','Drop','Grant','References','Index','Alter') DEFAULT '' NOT NULL, "
c_t = " $c_t Column_priv set('Select','Insert','Update','References') DEFAULT '' NOT NULL, "
c_t = " $c_t PRIMARY KEY (Host,Db,User,Table_name), "
c_t = " $c_t KEY Grantor (Grantor) "
c_t = " $c_t ) "
c_t = " $c_t comment='Table privileges'; "
fi
if test ! -f $mdata /columns_priv.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing columns_priv table" 1>& 2;
fi
c_c = " $c_c CREATE TABLE columns_priv ( "
c_c = " $c_c Host char(60) binary DEFAULT '' NOT NULL, "
c_c = " $c_c Db char(64) binary DEFAULT '' NOT NULL, "
c_c = " $c_c User char(16) binary DEFAULT '' NOT NULL, "
c_c = " $c_c Table_name char(64) binary DEFAULT '' NOT NULL, "
c_c = " $c_c Column_name char(64) binary DEFAULT '' NOT NULL, "
c_c = " $c_c Timestamp timestamp(14), "
c_c = " $c_c Column_priv set('Select','Insert','Update','References') DEFAULT '' NOT NULL, "
c_c = " $c_c PRIMARY KEY (Host,Db,User,Table_name,Column_name) "
c_c = " $c_c ) "
c_c = " $c_c comment='Column privileges'; "
fi
if test ! -f $mdata /help_topic.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing help_topic table" 1>& 2;
fi
c_ht = " $c_ht CREATE TABLE help_topic ( "
c_ht = " $c_ht help_topic_id int unsigned not null, "
c_ht = " $c_ht name varchar(64) not null, "
c_ht = " $c_ht help_category_id smallint unsigned not null, "
c_ht = " $c_ht description text not null, "
c_ht = " $c_ht example text not null, "
c_ht = " $c_ht url varchar(128) not null, "
c_ht = " $c_ht primary key (help_topic_id), "
c_ht = " $c_ht unique index (name) "
c_ht = " $c_ht ) "
c_ht = " $c_ht comment='help topics'; "
fi
old_categories = "yes"
if test ! -f $mdata /help_category.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing help_category table" 1>& 2;
fi
c_hc = " $c_hc CREATE TABLE help_category ( "
c_hc = " $c_hc help_category_id smallint unsigned not null, "
c_hc = " $c_hc name varchar(64) not null, "
c_hc = " $c_hc parent_category_id smallint unsigned null, "
c_hc = " $c_hc url varchar(128) not null, "
c_hc = " $c_hc primary key (help_category_id), "
c_hc = " $c_hc unique index (name) "
c_hc = " $c_hc ) "
c_hc = " $c_hc comment='help categories'; "
fi
if test ! -f $mdata /help_keyword.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing help_keyword table" 1>& 2;
fi
c_hk = " $c_hk CREATE TABLE help_keyword ( "
c_hk = " $c_hk help_keyword_id int unsigned not null, "
c_hk = " $c_hk name varchar(64) not null, "
c_hk = " $c_hk primary key (help_keyword_id), "
c_hk = " $c_hk unique index (name) "
c_hk = " $c_hk ) "
c_hk = " $c_hk comment='help keywords'; "
fi
if test ! -f $mdata /help_relation.frm
then
2003-06-15 22:24:37 +02:00
if test " $1 " = "verbose" ; then
2003-05-29 23:47:31 +02:00
echo "Preparing help_relation table" 1>& 2;
fi
c_hr = " $c_hr CREATE TABLE help_relation ( "
c_hr = " $c_hr help_topic_id int unsigned not null references help_topic, "
c_hr = " $c_hr help_keyword_id int unsigned not null references help_keyword, "
c_hr = " $c_hr primary key (help_keyword_id, help_topic_id) "
c_hr = " $c_hr ) "
c_hr = " $c_hr comment='keyword-topic relation'; "
fi
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
if test ! -f $mdata /time_zone_name.frm
then
if test " $1 " = "verbose" ; then
echo "Preparing time_zone_name table" 1>& 2;
fi
c_tzn = " $c_tzn CREATE TABLE time_zone_name ( "
c_tzn = " $c_tzn Name char(64) NOT NULL, "
c_tzn = " $c_tzn Time_zone_id int unsigned NOT NULL, "
c_tzn = " $c_tzn PRIMARY KEY Name (Name) "
c_tzn = " $c_tzn ) DEFAULT CHARACTER SET latin1 "
c_tzn = " $c_tzn comment='Time zone names'; "
if test " $1 " = "test"
then
i_tzn = " $i_tzn INSERT INTO time_zone_name (Name, Time_Zone_id) VALUES "
i_tzn = " $i_tzn ('MET', 1), ('UTC', 2), ('Universal', 2), "
2004-08-10 10:42:31 +02:00
i_tzn = " $i_tzn ('Europe/Moscow',3), ('leap/Europe/Moscow',4), "
i_tzn = " $i_tzn ('Japan', 5); "
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
fi
fi
if test ! -f $mdata /time_zone.frm
then
if test " $1 " = "verbose" ; then
echo "Preparing time_zone table" 1>& 2;
fi
c_tz = " $c_tz CREATE TABLE time_zone ( "
c_tz = " $c_tz Time_zone_id int unsigned NOT NULL auto_increment, "
c_tz = " $c_tz Use_leap_seconds enum('Y','N') DEFAULT 'N' NOT NULL, "
c_tz = " $c_tz PRIMARY KEY TzId (Time_zone_id) "
c_tz = " $c_tz ) DEFAULT CHARACTER SET latin1 "
c_tz = " $c_tz comment='Time zones'; "
if test " $1 " = "test"
then
i_tz = " $i_tz INSERT INTO time_zone (Time_zone_id, Use_leap_seconds) "
2004-08-10 10:42:31 +02:00
i_tz = " $i_tz VALUES (1,'N'), (2,'N'), (3,'N'), (4,'Y'), (5,'N'); "
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
fi
fi
if test ! -f $mdata /time_zone_transition.frm
then
if test " $1 " = "verbose" ; then
echo "Preparing time_zone_transition table" 1>& 2;
fi
c_tzt = " $c_tzt CREATE TABLE time_zone_transition ( "
c_tzt = " $c_tzt Time_zone_id int unsigned NOT NULL, "
c_tzt = " $c_tzt Transition_time bigint signed NOT NULL, "
c_tzt = " $c_tzt Transition_type_id int unsigned NOT NULL, "
c_tzt = " $c_tzt PRIMARY KEY TzIdTranTime (Time_zone_id, Transition_time) "
c_tzt = " $c_tzt ) DEFAULT CHARACTER SET latin1 "
c_tzt = " $c_tzt comment='Time zone transitions'; "
if test " $1 " = "test"
then
i_tzt = " $i_tzt INSERT INTO time_zone_transition "
i_tzt = " $i_tzt (Time_zone_id, Transition_time, Transition_type_id) "
i_tzt = " $i_tzt VALUES "
i_tzt = " $i_tzt (1, -1693706400, 0) ,(1, -1680483600, 1) "
i_tzt = " $i_tzt ,(1, -1663455600, 2) ,(1, -1650150000, 3) "
i_tzt = " $i_tzt ,(1, -1632006000, 2) ,(1, -1618700400, 3) "
i_tzt = " $i_tzt ,(1, -938905200, 2) ,(1, -857257200, 3) "
i_tzt = " $i_tzt ,(1, -844556400, 2) ,(1, -828226800, 3) "
i_tzt = " $i_tzt ,(1, -812502000, 2) ,(1, -796777200, 3) "
i_tzt = " $i_tzt ,(1, 228877200, 2) ,(1, 243997200, 3) "
i_tzt = " $i_tzt ,(1, 260326800, 2) ,(1, 276051600, 3) "
i_tzt = " $i_tzt ,(1, 291776400, 2) ,(1, 307501200, 3) "
i_tzt = " $i_tzt ,(1, 323830800, 2) ,(1, 338950800, 3) "
i_tzt = " $i_tzt ,(1, 354675600, 2) ,(1, 370400400, 3) "
i_tzt = " $i_tzt ,(1, 386125200, 2) ,(1, 401850000, 3) "
i_tzt = " $i_tzt ,(1, 417574800, 2) ,(1, 433299600, 3) "
i_tzt = " $i_tzt ,(1, 449024400, 2) ,(1, 465354000, 3) "
i_tzt = " $i_tzt ,(1, 481078800, 2) ,(1, 496803600, 3) "
i_tzt = " $i_tzt ,(1, 512528400, 2) ,(1, 528253200, 3) "
i_tzt = " $i_tzt ,(1, 543978000, 2) ,(1, 559702800, 3) "
i_tzt = " $i_tzt ,(1, 575427600, 2) ,(1, 591152400, 3) "
i_tzt = " $i_tzt ,(1, 606877200, 2) ,(1, 622602000, 3) "
i_tzt = " $i_tzt ,(1, 638326800, 2) ,(1, 654656400, 3) "
i_tzt = " $i_tzt ,(1, 670381200, 2) ,(1, 686106000, 3) "
i_tzt = " $i_tzt ,(1, 701830800, 2) ,(1, 717555600, 3) "
i_tzt = " $i_tzt ,(1, 733280400, 2) ,(1, 749005200, 3) "
i_tzt = " $i_tzt ,(1, 764730000, 2) ,(1, 780454800, 3) "
i_tzt = " $i_tzt ,(1, 796179600, 2) ,(1, 811904400, 3) "
i_tzt = " $i_tzt ,(1, 828234000, 2) ,(1, 846378000, 3) "
i_tzt = " $i_tzt ,(1, 859683600, 2) ,(1, 877827600, 3) "
i_tzt = " $i_tzt ,(1, 891133200, 2) ,(1, 909277200, 3) "
i_tzt = " $i_tzt ,(1, 922582800, 2) ,(1, 941331600, 3) "
i_tzt = " $i_tzt ,(1, 954032400, 2) ,(1, 972781200, 3) "
i_tzt = " $i_tzt ,(1, 985482000, 2) ,(1, 1004230800, 3) "
i_tzt = " $i_tzt ,(1, 1017536400, 2) ,(1, 1035680400, 3) "
i_tzt = " $i_tzt ,(1, 1048986000, 2) ,(1, 1067130000, 3) "
i_tzt = " $i_tzt ,(1, 1080435600, 2) ,(1, 1099184400, 3) "
i_tzt = " $i_tzt ,(1, 1111885200, 2) ,(1, 1130634000, 3) "
i_tzt = " $i_tzt ,(1, 1143334800, 2) ,(1, 1162083600, 3) "
i_tzt = " $i_tzt ,(1, 1174784400, 2) ,(1, 1193533200, 3) "
i_tzt = " $i_tzt ,(1, 1206838800, 2) ,(1, 1224982800, 3) "
i_tzt = " $i_tzt ,(1, 1238288400, 2) ,(1, 1256432400, 3) "
i_tzt = " $i_tzt ,(1, 1269738000, 2) ,(1, 1288486800, 3) "
i_tzt = " $i_tzt ,(1, 1301187600, 2) ,(1, 1319936400, 3) "
i_tzt = " $i_tzt ,(1, 1332637200, 2) ,(1, 1351386000, 3) "
i_tzt = " $i_tzt ,(1, 1364691600, 2) ,(1, 1382835600, 3) "
i_tzt = " $i_tzt ,(1, 1396141200, 2) ,(1, 1414285200, 3) "
i_tzt = " $i_tzt ,(1, 1427590800, 2) ,(1, 1445734800, 3) "
i_tzt = " $i_tzt ,(1, 1459040400, 2) ,(1, 1477789200, 3) "
i_tzt = " $i_tzt ,(1, 1490490000, 2) ,(1, 1509238800, 3) "
i_tzt = " $i_tzt ,(1, 1521939600, 2) ,(1, 1540688400, 3) "
i_tzt = " $i_tzt ,(1, 1553994000, 2) ,(1, 1572138000, 3) "
i_tzt = " $i_tzt ,(1, 1585443600, 2) ,(1, 1603587600, 3) "
i_tzt = " $i_tzt ,(1, 1616893200, 2) ,(1, 1635642000, 3) "
i_tzt = " $i_tzt ,(1, 1648342800, 2) ,(1, 1667091600, 3) "
i_tzt = " $i_tzt ,(1, 1679792400, 2) ,(1, 1698541200, 3) "
i_tzt = " $i_tzt ,(1, 1711846800, 2) ,(1, 1729990800, 3) "
i_tzt = " $i_tzt ,(1, 1743296400, 2) ,(1, 1761440400, 3) "
i_tzt = " $i_tzt ,(1, 1774746000, 2) ,(1, 1792890000, 3) "
i_tzt = " $i_tzt ,(1, 1806195600, 2) ,(1, 1824944400, 3) "
i_tzt = " $i_tzt ,(1, 1837645200, 2) ,(1, 1856394000, 3) "
i_tzt = " $i_tzt ,(1, 1869094800, 2) ,(1, 1887843600, 3) "
i_tzt = " $i_tzt ,(1, 1901149200, 2) ,(1, 1919293200, 3) "
i_tzt = " $i_tzt ,(1, 1932598800, 2) ,(1, 1950742800, 3) "
i_tzt = " $i_tzt ,(1, 1964048400, 2) ,(1, 1982797200, 3) "
i_tzt = " $i_tzt ,(1, 1995498000, 2) ,(1, 2014246800, 3) "
i_tzt = " $i_tzt ,(1, 2026947600, 2) ,(1, 2045696400, 3) "
i_tzt = " $i_tzt ,(1, 2058397200, 2) ,(1, 2077146000, 3) "
i_tzt = " $i_tzt ,(1, 2090451600, 2) ,(1, 2108595600, 3) "
i_tzt = " $i_tzt ,(1, 2121901200, 2) ,(1, 2140045200, 3) "
i_tzt = " $i_tzt ,(3, -1688265000, 2) ,(3, -1656819048, 1) "
i_tzt = " $i_tzt ,(3, -1641353448, 2) ,(3, -1627965048, 3) "
i_tzt = " $i_tzt ,(3, -1618716648, 1) ,(3, -1596429048, 3) "
i_tzt = " $i_tzt ,(3, -1593829848, 5) ,(3, -1589860800, 4) "
i_tzt = " $i_tzt ,(3, -1542427200, 5) ,(3, -1539493200, 6) "
i_tzt = " $i_tzt ,(3, -1525323600, 5) ,(3, -1522728000, 4) "
i_tzt = " $i_tzt ,(3, -1491188400, 7) ,(3, -1247536800, 4) "
i_tzt = " $i_tzt ,(3, 354920400, 5) ,(3, 370728000, 4) "
i_tzt = " $i_tzt ,(3, 386456400, 5) ,(3, 402264000, 4) "
i_tzt = " $i_tzt ,(3, 417992400, 5) ,(3, 433800000, 4) "
i_tzt = " $i_tzt ,(3, 449614800, 5) ,(3, 465346800, 8) "
i_tzt = " $i_tzt ,(3, 481071600, 9) ,(3, 496796400, 8) "
i_tzt = " $i_tzt ,(3, 512521200, 9) ,(3, 528246000, 8) "
i_tzt = " $i_tzt ,(3, 543970800, 9) ,(3, 559695600, 8) "
i_tzt = " $i_tzt ,(3, 575420400, 9) ,(3, 591145200, 8) "
i_tzt = " $i_tzt ,(3, 606870000, 9) ,(3, 622594800, 8) "
i_tzt = " $i_tzt ,(3, 638319600, 9) ,(3, 654649200, 8) "
i_tzt = " $i_tzt ,(3, 670374000, 10) ,(3, 686102400, 11) "
i_tzt = " $i_tzt ,(3, 695779200, 8) ,(3, 701812800, 5) "
i_tzt = " $i_tzt ,(3, 717534000, 4) ,(3, 733273200, 9) "
i_tzt = " $i_tzt ,(3, 748998000, 8) ,(3, 764722800, 9) "
i_tzt = " $i_tzt ,(3, 780447600, 8) ,(3, 796172400, 9) "
i_tzt = " $i_tzt ,(3, 811897200, 8) ,(3, 828226800, 9) "
i_tzt = " $i_tzt ,(3, 846370800, 8) ,(3, 859676400, 9) "
i_tzt = " $i_tzt ,(3, 877820400, 8) ,(3, 891126000, 9) "
i_tzt = " $i_tzt ,(3, 909270000, 8) ,(3, 922575600, 9) "
i_tzt = " $i_tzt ,(3, 941324400, 8) ,(3, 954025200, 9) "
i_tzt = " $i_tzt ,(3, 972774000, 8) ,(3, 985474800, 9) "
i_tzt = " $i_tzt ,(3, 1004223600, 8) ,(3, 1017529200, 9) "
i_tzt = " $i_tzt ,(3, 1035673200, 8) ,(3, 1048978800, 9) "
i_tzt = " $i_tzt ,(3, 1067122800, 8) ,(3, 1080428400, 9) "
i_tzt = " $i_tzt ,(3, 1099177200, 8) ,(3, 1111878000, 9) "
i_tzt = " $i_tzt ,(3, 1130626800, 8) ,(3, 1143327600, 9) "
i_tzt = " $i_tzt ,(3, 1162076400, 8) ,(3, 1174777200, 9) "
i_tzt = " $i_tzt ,(3, 1193526000, 8) ,(3, 1206831600, 9) "
i_tzt = " $i_tzt ,(3, 1224975600, 8) ,(3, 1238281200, 9) "
i_tzt = " $i_tzt ,(3, 1256425200, 8) ,(3, 1269730800, 9) "
i_tzt = " $i_tzt ,(3, 1288479600, 8) ,(3, 1301180400, 9) "
i_tzt = " $i_tzt ,(3, 1319929200, 8) ,(3, 1332630000, 9) "
i_tzt = " $i_tzt ,(3, 1351378800, 8) ,(3, 1364684400, 9) "
i_tzt = " $i_tzt ,(3, 1382828400, 8) ,(3, 1396134000, 9) "
i_tzt = " $i_tzt ,(3, 1414278000, 8) ,(3, 1427583600, 9) "
i_tzt = " $i_tzt ,(3, 1445727600, 8) ,(3, 1459033200, 9) "
i_tzt = " $i_tzt ,(3, 1477782000, 8) ,(3, 1490482800, 9) "
i_tzt = " $i_tzt ,(3, 1509231600, 8) ,(3, 1521932400, 9) "
i_tzt = " $i_tzt ,(3, 1540681200, 8) ,(3, 1553986800, 9) "
i_tzt = " $i_tzt ,(3, 1572130800, 8) ,(3, 1585436400, 9) "
i_tzt = " $i_tzt ,(3, 1603580400, 8) ,(3, 1616886000, 9) "
i_tzt = " $i_tzt ,(3, 1635634800, 8) ,(3, 1648335600, 9) "
i_tzt = " $i_tzt ,(3, 1667084400, 8) ,(3, 1679785200, 9) "
i_tzt = " $i_tzt ,(3, 1698534000, 8) ,(3, 1711839600, 9) "
i_tzt = " $i_tzt ,(3, 1729983600, 8) ,(3, 1743289200, 9) "
i_tzt = " $i_tzt ,(3, 1761433200, 8) ,(3, 1774738800, 9) "
i_tzt = " $i_tzt ,(3, 1792882800, 8) ,(3, 1806188400, 9) "
i_tzt = " $i_tzt ,(3, 1824937200, 8) ,(3, 1837638000, 9) "
i_tzt = " $i_tzt ,(3, 1856386800, 8) ,(3, 1869087600, 9) "
i_tzt = " $i_tzt ,(3, 1887836400, 8) ,(3, 1901142000, 9) "
i_tzt = " $i_tzt ,(3, 1919286000, 8) ,(3, 1932591600, 9) "
i_tzt = " $i_tzt ,(3, 1950735600, 8) ,(3, 1964041200, 9) "
i_tzt = " $i_tzt ,(3, 1982790000, 8) ,(3, 1995490800, 9) "
i_tzt = " $i_tzt ,(3, 2014239600, 8) ,(3, 2026940400, 9) "
i_tzt = " $i_tzt ,(3, 2045689200, 8) ,(3, 2058390000, 9) "
i_tzt = " $i_tzt ,(3, 2077138800, 8) ,(3, 2090444400, 9) "
i_tzt = " $i_tzt ,(3, 2108588400, 8) ,(3, 2121894000, 9) "
i_tzt = " $i_tzt ,(3, 2140038000, 8) "
i_tzt = " $i_tzt ,(4, -1688265000, 2) ,(4, -1656819048, 1) "
i_tzt = " $i_tzt ,(4, -1641353448, 2) ,(4, -1627965048, 3) "
i_tzt = " $i_tzt ,(4, -1618716648, 1) ,(4, -1596429048, 3) "
i_tzt = " $i_tzt ,(4, -1593829848, 5) ,(4, -1589860800, 4) "
i_tzt = " $i_tzt ,(4, -1542427200, 5) ,(4, -1539493200, 6) "
i_tzt = " $i_tzt ,(4, -1525323600, 5) ,(4, -1522728000, 4) "
i_tzt = " $i_tzt ,(4, -1491188400, 7) ,(4, -1247536800, 4) "
i_tzt = " $i_tzt ,(4, 354920409, 5) ,(4, 370728010, 4) "
i_tzt = " $i_tzt ,(4, 386456410, 5) ,(4, 402264011, 4) "
i_tzt = " $i_tzt ,(4, 417992411, 5) ,(4, 433800012, 4) "
i_tzt = " $i_tzt ,(4, 449614812, 5) ,(4, 465346812, 8) "
i_tzt = " $i_tzt ,(4, 481071612, 9) ,(4, 496796413, 8) "
i_tzt = " $i_tzt ,(4, 512521213, 9) ,(4, 528246013, 8) "
i_tzt = " $i_tzt ,(4, 543970813, 9) ,(4, 559695613, 8) "
i_tzt = " $i_tzt ,(4, 575420414, 9) ,(4, 591145214, 8) "
i_tzt = " $i_tzt ,(4, 606870014, 9) ,(4, 622594814, 8) "
i_tzt = " $i_tzt ,(4, 638319615, 9) ,(4, 654649215, 8) "
i_tzt = " $i_tzt ,(4, 670374016, 10) ,(4, 686102416, 11) "
i_tzt = " $i_tzt ,(4, 695779216, 8) ,(4, 701812816, 5) "
i_tzt = " $i_tzt ,(4, 717534017, 4) ,(4, 733273217, 9) "
i_tzt = " $i_tzt ,(4, 748998018, 8) ,(4, 764722818, 9) "
i_tzt = " $i_tzt ,(4, 780447619, 8) ,(4, 796172419, 9) "
i_tzt = " $i_tzt ,(4, 811897219, 8) ,(4, 828226820, 9) "
i_tzt = " $i_tzt ,(4, 846370820, 8) ,(4, 859676420, 9) "
i_tzt = " $i_tzt ,(4, 877820421, 8) ,(4, 891126021, 9) "
i_tzt = " $i_tzt ,(4, 909270021, 8) ,(4, 922575622, 9) "
i_tzt = " $i_tzt ,(4, 941324422, 8) ,(4, 954025222, 9) "
i_tzt = " $i_tzt ,(4, 972774022, 8) ,(4, 985474822, 9) "
i_tzt = " $i_tzt ,(4, 1004223622, 8) ,(4, 1017529222, 9) "
i_tzt = " $i_tzt ,(4, 1035673222, 8) ,(4, 1048978822, 9) "
i_tzt = " $i_tzt ,(4, 1067122822, 8) ,(4, 1080428422, 9) "
i_tzt = " $i_tzt ,(4, 1099177222, 8) ,(4, 1111878022, 9) "
i_tzt = " $i_tzt ,(4, 1130626822, 8) ,(4, 1143327622, 9) "
i_tzt = " $i_tzt ,(4, 1162076422, 8) ,(4, 1174777222, 9) "
i_tzt = " $i_tzt ,(4, 1193526022, 8) ,(4, 1206831622, 9) "
i_tzt = " $i_tzt ,(4, 1224975622, 8) ,(4, 1238281222, 9) "
i_tzt = " $i_tzt ,(4, 1256425222, 8) ,(4, 1269730822, 9) "
i_tzt = " $i_tzt ,(4, 1288479622, 8) ,(4, 1301180422, 9) "
i_tzt = " $i_tzt ,(4, 1319929222, 8) ,(4, 1332630022, 9) "
i_tzt = " $i_tzt ,(4, 1351378822, 8) ,(4, 1364684422, 9) "
i_tzt = " $i_tzt ,(4, 1382828422, 8) ,(4, 1396134022, 9) "
i_tzt = " $i_tzt ,(4, 1414278022, 8) ,(4, 1427583622, 9) "
i_tzt = " $i_tzt ,(4, 1445727622, 8) ,(4, 1459033222, 9) "
i_tzt = " $i_tzt ,(4, 1477782022, 8) ,(4, 1490482822, 9) "
i_tzt = " $i_tzt ,(4, 1509231622, 8) ,(4, 1521932422, 9) "
i_tzt = " $i_tzt ,(4, 1540681222, 8) ,(4, 1553986822, 9) "
i_tzt = " $i_tzt ,(4, 1572130822, 8) ,(4, 1585436422, 9) "
i_tzt = " $i_tzt ,(4, 1603580422, 8) ,(4, 1616886022, 9) "
i_tzt = " $i_tzt ,(4, 1635634822, 8) ,(4, 1648335622, 9) "
i_tzt = " $i_tzt ,(4, 1667084422, 8) ,(4, 1679785222, 9) "
i_tzt = " $i_tzt ,(4, 1698534022, 8) ,(4, 1711839622, 9) "
i_tzt = " $i_tzt ,(4, 1729983622, 8) ,(4, 1743289222, 9) "
i_tzt = " $i_tzt ,(4, 1761433222, 8) ,(4, 1774738822, 9) "
i_tzt = " $i_tzt ,(4, 1792882822, 8) ,(4, 1806188422, 9) "
i_tzt = " $i_tzt ,(4, 1824937222, 8) ,(4, 1837638022, 9) "
i_tzt = " $i_tzt ,(4, 1856386822, 8) ,(4, 1869087622, 9) "
i_tzt = " $i_tzt ,(4, 1887836422, 8) ,(4, 1901142022, 9) "
i_tzt = " $i_tzt ,(4, 1919286022, 8) ,(4, 1932591622, 9) "
i_tzt = " $i_tzt ,(4, 1950735622, 8) ,(4, 1964041222, 9) "
i_tzt = " $i_tzt ,(4, 1982790022, 8) ,(4, 1995490822, 9) "
i_tzt = " $i_tzt ,(4, 2014239622, 8) ,(4, 2026940422, 9) "
i_tzt = " $i_tzt ,(4, 2045689222, 8) ,(4, 2058390022, 9) "
i_tzt = " $i_tzt ,(4, 2077138822, 8) ,(4, 2090444422, 9) "
i_tzt = " $i_tzt ,(4, 2108588422, 8) ,(4, 2121894022, 9) "
2004-08-10 10:42:31 +02:00
i_tzt = " $i_tzt ,(4, 2140038022, 8) "
i_tzt = " $i_tzt ,(5, -1009875600, 1); "
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
fi
fi
if test ! -f $mdata /time_zone_transition_type.frm
then
if test " $1 " = "verbose" ; then
echo "Preparing time_zone_transition_type table" 1>& 2;
fi
c_tztt = " $c_tztt CREATE TABLE time_zone_transition_type ( "
c_tztt = " $c_tztt Time_zone_id int unsigned NOT NULL, "
c_tztt = " $c_tztt Transition_type_id int unsigned NOT NULL, "
c_tztt = " $c_tztt Offset int signed DEFAULT 0 NOT NULL, "
c_tztt = " $c_tztt Is_DST tinyint unsigned DEFAULT 0 NOT NULL, "
c_tztt = " $c_tztt Abbreviation char(8) DEFAULT '' NOT NULL, "
c_tztt = " $c_tztt PRIMARY KEY TzIdTrTId (Time_zone_id, Transition_type_id) "
c_tztt = " $c_tztt ) DEFAULT CHARACTER SET latin1 "
c_tztt = " $c_tztt comment='Time zone transition types'; "
if test " $1 " = "test"
then
i_tztt = " $i_tztt INSERT INTO time_zone_transition_type (Time_zone_id, "
i_tztt = " $i_tztt Transition_type_id, Offset, Is_DST, Abbreviation) VALUES "
i_tztt = " $i_tztt (1, 0, 7200, 1, 'MEST') ,(1, 1, 3600, 0, 'MET') "
i_tztt = " $i_tztt ,(1, 2, 7200, 1, 'MEST') ,(1, 3, 3600, 0, 'MET') "
i_tztt = " $i_tztt ,(2, 0, 0, 0, 'UTC') "
i_tztt = " $i_tztt ,(3, 0, 9000, 0, 'MMT') ,(3, 1, 12648, 1, 'MST') "
i_tztt = " $i_tztt ,(3, 2, 9048, 0, 'MMT') ,(3, 3, 16248, 1, 'MDST') "
i_tztt = " $i_tztt ,(3, 4, 10800, 0, 'MSK') ,(3, 5, 14400, 1, 'MSD') "
i_tztt = " $i_tztt ,(3, 6, 18000, 1, 'MSD') ,(3, 7, 7200, 0, 'EET') "
i_tztt = " $i_tztt ,(3, 8, 10800, 0, 'MSK') ,(3, 9, 14400, 1, 'MSD') "
i_tztt = " $i_tztt ,(3, 10, 10800, 1, 'EEST') ,(3, 11, 7200, 0, 'EET') "
i_tztt = " $i_tztt ,(4, 0, 9000, 0, 'MMT') ,(4, 1, 12648, 1, 'MST') "
i_tztt = " $i_tztt ,(4, 2, 9048, 0, 'MMT') ,(4, 3, 16248, 1, 'MDST') "
i_tztt = " $i_tztt ,(4, 4, 10800, 0, 'MSK') ,(4, 5, 14400, 1, 'MSD') "
i_tztt = " $i_tztt ,(4, 6, 18000, 1, 'MSD') ,(4, 7, 7200, 0, 'EET') "
i_tztt = " $i_tztt ,(4, 8, 10800, 0, 'MSK') ,(4, 9, 14400, 1, 'MSD') "
2004-08-10 10:42:31 +02:00
i_tztt = " $i_tztt ,(4, 10, 10800, 1, 'EEST') ,(4, 11, 7200, 0, 'EET') "
i_tztt = " $i_tztt ,(5, 0, 32400, 0, 'CJT') ,(5, 1, 32400, 0, 'JST'); "
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
fi
fi
if test ! -f $mdata /time_zone_leap_second.frm
then
if test " $1 " = "verbose" ; then
echo "Preparing time_zone_leap_second table" 1>& 2;
fi
c_tzls = " $c_tzls CREATE TABLE time_zone_leap_second ( "
c_tzls = " $c_tzls Transition_time bigint signed NOT NULL, "
c_tzls = " $c_tzls Correction int signed NOT NULL, "
c_tzls = " $c_tzls PRIMARY KEY TranTime (Transition_time) "
c_tzls = " $c_tzls ) DEFAULT CHARACTER SET latin1 "
c_tzls = " $c_tzls comment='Leap seconds information for time zones'; "
if test " $1 " = "test"
then
i_tzls = " $i_tzls INSERT INTO time_zone_leap_second "
i_tzls = " $i_tzls (Transition_time, Correction) VALUES "
i_tzls = " $i_tzls (78796800, 1) ,(94694401, 2) ,(126230402, 3) "
i_tzls = " $i_tzls ,(157766403, 4) ,(189302404, 5) ,(220924805, 6) "
i_tzls = " $i_tzls ,(252460806, 7) ,(283996807, 8) ,(315532808, 9) "
i_tzls = " $i_tzls ,(362793609, 10) ,(394329610, 11) ,(425865611, 12) "
i_tzls = " $i_tzls ,(489024012, 13) ,(567993613, 14) ,(631152014, 15) "
i_tzls = " $i_tzls ,(662688015, 16) ,(709948816, 17) ,(741484817, 18) "
i_tzls = " $i_tzls ,(773020818, 19) ,(820454419, 20) ,(867715220, 21) "
i_tzls = " $i_tzls ,(915148821, 22); "
fi
fi
2003-05-29 23:47:31 +02:00
cat << END_OF_DATA
use mysql;
$c_d
$i_d
$c_h
$i_h
$c_u
$i_u
$c_f
$i_f
$c_t
$c_c
$c_ht
$c_hc
$c_hr
$c_hk
WL#1264 "Per-thread time zone support infrastructure".
Added basic per-thread time zone functionality (based on public
domain elsie-code). Now user can select current time zone
(from the list of time zones described in system tables).
All NOW-like functions honor this time zone, values of TIMESTAMP
type are interpreted as values in this time zone, so now
our TIMESTAMP type behaves similar to Oracle's TIMESTAMP WITH
LOCAL TIME ZONE (or proper PostgresSQL type).
WL#1266 "CONVERT_TZ() - basic time with time zone conversion
function".
Fixed problems described in Bug #2336 (Different number of warnings
when inserting bad datetime as string or as number). This required
reworking of datetime realted warning hadling (they now generated
at Field object level not in conversion functions).
Optimization: Now Field class descendants use table->in_use member
instead of current_thd macro.
include/my_global.h:
Added macro for reading of 32-bit ints stored in network order from
unaligned memory location.
include/mysqld_error.h:
Added error-code for invalid timestamp warning and error-code
for wrong or unknown time zone specification.
libmysqld/Makefile.am:
Added main per-thread time zone support file to libmysqld
libmysqld/lib_sql.cc:
Added initialization of time zones infrastructure to embedded server.
mysql-test/r/connect.result:
Updated test result since now mysql database contains more
system tables.
mysql-test/r/date_formats.result:
Now when truncation occurs during conversion to datetime value we are producing Warnings
instead of Notes. Also we are giving more clear warnings about this in some cases.
mysql-test/r/func_sapdb.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/func_time.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling.
mysql-test/r/select.result:
New warnings about truncation occured during conversion to datetime value added due
their better handling. Also tweaked test a bit to made it less ambigious for reader.
mysql-test/r/system_mysql_db.result:
Updated test result because new system tables holding time zone descriptions were
added.
mysql-test/r/timezone.result:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/r/type_datetime.result:
Separated and extended test of values and warnings produced for bad values stored in
DATETTIME fields.
mysql-test/r/type_time.result:
Now we are producing more consistent warning when we are truncating datetime value while
storing it in TIME field.
mysql-test/r/type_timestamp.result:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
mysql-test/t/select.test:
Updated test to make it less ambigous for reader.
mysql-test/t/timezone.test:
Updated timezone.test to use new system variable which shows system time zone.
Added test of warning which is produced if someone tries to store non-existing (due
falling into spring time-gap) datetime value into TIMESTAMP field.
mysql-test/t/type_datetime.test:
Separated and extended test of values and warnings produced for bad
values stored in DATETTIME fields.
mysql-test/t/type_timestamp.test:
Separated and extended test of values and warnings produced for bad
values stored in TIMESTAMP fields.
scripts/mysql_create_system_tables.sh:
Added creation of tables with time zone descriptions.
Also added descriptions of time zones used in tests.
scripts/mysql_fix_privilege_tables.sql:
Added mysql.time_zone* tables family.
sql/Makefile.am:
Added files implementing time zone support to server, also added
rules for building of mysql_tzinfo_to_sql converter and test_time
test.
sql/field.cc:
Now we are using per-thread time zone for TIMESTAMP <-> whatever conversion.
Fixed generation of warnings for datetime types (DATETIME/TIMESTAMP/DATE/...) and
any other Field to datetime conversion (now we are generating warnings no in lower
level functions like in str_to_TIME() but in Field methods. This allows generate
better and more consistent warnings and to reuse code of str_to_TIME() outside of
server).
Added 3rd parameter to set_warning() method to be able to not increment cut fields
but still produce a warning. Also added set_datetime_warning() family of auxiliary
methods which allow easier generate datetime related warnings.
Also replaced occurences of current_thd with table->in_use member, added
asserts for catching all places there we need to set table->in_use
accordingly. Renamed fix_datetime() function to number_to_TIME() and
moved it to sql/time.cc there it fits better.
sql/field.h:
Added comment about places where we can use table->in_use member
instead of current_thd.
Added 3rd parameter to Field::set_warning() method and set_datetime_warning()
family of methods.
sql/field_conv.cc:
Field::set_warning() method with 2 arguments was replaced with more
generic set_warning() method with 3 arguments.
sql/ha_berkeley.cc:
Now we set table->in_use for temporary tables so we have to use
table->tmp_table for checking if table is temporary.
sql/item.cc:
Replaced calls to str_to_time() and str_to_TIME() funcs with their warning
generating analogs.
sql/item_create.cc:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_create.h:
Added creation of CONVERT_TZ function as FUNC_ARG3.
sql/item_timefunc.cc:
Added support of per-thread time zone to NOW-like and FROM_UNIXTIME,
UNIX_TIMESTAMP functions.
Added support for CONVERT_TZ function.
Removed call to str_to_timestamp function which caused non-optimal
behavior in certain cases. Replaced calls to str_to_time() function
with its warning generating analog.
sql/item_timefunc.h:
Added support of per-thread time zone to NOW-like and
FROM_UNIXTIME, UNIX_TIMESTAMP functions.
Added support of CONVERT_TZ function.
sql/lex.h:
Added support of CONVERT_TZ function.
sql/log.cc:
Added support for replication of statements depending on time zone.
sql/mysql_priv.h:
Now including headers with per-thread time zone support functions
and classes. Added portable replacement of time_t - my_time_t type.
Added time zone as one of query distinguishing parameters for
query cache.
Fixed declarations of str_to_TIME, str_to_time and
my_system_gmt_sec (former my_gmt_sec) since now they have one more
out parameter which informs about wrong datetime value or data
truncation during conversion.
Added warning generating version of str_to_TIME() and str_to_time()
functions.
Thrown away str_to_datetime/timestamp functions since they are not
needed any longer. Added number_to_TIME function.
sql/mysqld.cc:
Added per-thread time zone support initialization.
Added new startup parameter --default-time-zone.
sql/set_var.cc:
Added support for per-thread time_zone variable.
Renamed old timezone variable to system_time_zone.
sql/set_var.h:
Added support for per-thread time_zone variable.
sql/share/czech/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/danish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/dutch/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/english/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/estonian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/french/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/german/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/greek/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/hungarian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/italian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/japanese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/korean/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian-ny/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/norwegian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/polish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/portuguese/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/romanian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/russian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/serbian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/slovak/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/spanish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/swedish/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/share/ukrainian/errmsg.txt:
Added error message for barking when incorrect time zone name or
specifiaction is provided and for warning about invalid TIMESTAMP
values (e.g. falling into the spring time-gap).
sql/slave.cc:
In order to support replication of statements using time zones in 4.1 we should
ensure that both master and slave have same default time zone.
sql/sql_base.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_cache.cc:
Added time zone as one more query distinguishing parameter
for query cache.
sql/sql_class.cc:
Added THD::time_zone_used variable indicating that this query
uses per thread time zone.
sql/sql_class.h:
Added per-thread time zone variable. Added THD::time_zone_used
variable indicating that this query uses per thread time zone
so if this is updating query the time zone should be logged to
binlog.
sql/sql_insert.cc:
We should set TABLE::in_use member pointing to thread which is called
INSERT DELAYED and not to worker thread.
sql/sql_load.cc:
Field::set_warning() now has one more argument now.
sql/sql_parse.cc:
Resetting THD::time_zone_used variable in the end of query
processing.
sql/sql_select.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
sql/sql_show.cc:
Now using per thread time zone for extended show tables.
sql/time.cc:
Added support for per-thread time zones for TIMESTAMP type and
reworked generation of warnings for TIMESTAMP and DATETIME types.
(Introduced new TIME_to_timestamp() function. Removed hours
normalisation from former my_gmt_sec() since it was not working
and not used anywhere now, but breaks parameter constness, added
to this function generation of warning if we are falling in spring
time-gap. Removed str_to_timestamp and str_to_datetime functions
which are no longer used. Moved fix_datetime function from
sql/field.cc to this file as number_to_TIME() function. Added
out parameter for str_to_TIME and str_to_time functions which
indicates if value was truncated during conversion, removed direct
generation of warnings from this functions.)
sql/unireg.cc:
Now we are setting TABLE::in_use member for all tables (which assume
calls to Field::store or val_ methods).
BitKeeper/etc/ignore:
Added sql/test_time sql/mysql_tzinfo_to_sql libmysqld/tztime.cc to the ignore list
2004-06-18 08:11:31 +02:00
$c_tzn
$i_tzn
$c_tz
$i_tz
$c_tzt
$i_tzt
$c_tztt
$i_tztt
$c_tzls
$i_tzls
2003-05-29 23:47:31 +02:00
END_OF_DATA