mirror of
https://github.com/MariaDB/server.git
synced 2025-08-01 03:47:19 +03:00
SCRUM
Task ID 894: Backport default_week_format variable to 4.0 mysql-test/r/func_time.result: Backport default_week_format variable to 4.0 mysql-test/t/func_time.test: Backport default_week_format variable to 4.0 sql/mysqld.cc: Backport default_week_format variable to 4.0 sql/set_var.cc: Backport default_week_format variable to 4.0 sql/sql_class.h: Backport default_week_format variable to 4.0 sql/sql_yacc.yy: Backport default_week_format variable to 4.0
This commit is contained in:
@ -96,6 +96,11 @@ week(19981231,2) week(19981231,3) week(20000101,2) week(20000101,3)
|
|||||||
select week(20001231,2),week(20001231,3);
|
select week(20001231,2),week(20001231,3);
|
||||||
week(20001231,2) week(20001231,3)
|
week(20001231,2) week(20001231,3)
|
||||||
1 52
|
1 52
|
||||||
|
set default_week_format = 2;
|
||||||
|
select week(20001231),week(20001231,2),week(20001231,0);
|
||||||
|
week(20001231) week(20001231,2) week(20001231,0)
|
||||||
|
1 1 53
|
||||||
|
set default_week_format = 0;
|
||||||
select date_format('1998-12-31','%x-%v'),date_format('1999-01-01','%x-%v');
|
select date_format('1998-12-31','%x-%v'),date_format('1999-01-01','%x-%v');
|
||||||
date_format('1998-12-31','%x-%v') date_format('1999-01-01','%x-%v')
|
date_format('1998-12-31','%x-%v') date_format('1999-01-01','%x-%v')
|
||||||
1998-53 1998-53
|
1998-53 1998-53
|
||||||
|
@ -39,6 +39,10 @@ select yearweek("2000-01-06",1) as '2000', yearweek("2001-01-06",1) as '2001', y
|
|||||||
select week(19981231,2), week(19981231,3), week(20000101,2), week(20000101,3);
|
select week(19981231,2), week(19981231,3), week(20000101,2), week(20000101,3);
|
||||||
select week(20001231,2),week(20001231,3);
|
select week(20001231,2),week(20001231,3);
|
||||||
|
|
||||||
|
set default_week_format = 2;
|
||||||
|
select week(20001231),week(20001231,2),week(20001231,0);
|
||||||
|
set default_week_format = 0;
|
||||||
|
|
||||||
select date_format('1998-12-31','%x-%v'),date_format('1999-01-01','%x-%v');
|
select date_format('1998-12-31','%x-%v'),date_format('1999-01-01','%x-%v');
|
||||||
select date_format('1999-12-31','%x-%v'),date_format('2000-01-01','%x-%v');
|
select date_format('1999-12-31','%x-%v'),date_format('2000-01-01','%x-%v');
|
||||||
|
|
||||||
|
@ -3179,7 +3179,8 @@ enum options {
|
|||||||
OPT_BDB_CACHE_SIZE,
|
OPT_BDB_CACHE_SIZE,
|
||||||
OPT_BDB_LOG_BUFFER_SIZE,
|
OPT_BDB_LOG_BUFFER_SIZE,
|
||||||
OPT_BDB_MAX_LOCK,
|
OPT_BDB_MAX_LOCK,
|
||||||
OPT_ERROR_LOG_FILE
|
OPT_ERROR_LOG_FILE,
|
||||||
|
OPT_DEFAULT_WEEK_FORMAT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -3988,6 +3989,11 @@ replicating a LOAD DATA INFILE command",
|
|||||||
(gptr*) &global_system_variables.net_wait_timeout,
|
(gptr*) &global_system_variables.net_wait_timeout,
|
||||||
(gptr*) &max_system_variables.net_wait_timeout, 0, GET_ULONG,
|
(gptr*) &max_system_variables.net_wait_timeout, 0, GET_ULONG,
|
||||||
REQUIRED_ARG, NET_WAIT_TIMEOUT, 1, LONG_TIMEOUT, 0, 1, 0},
|
REQUIRED_ARG, NET_WAIT_TIMEOUT, 1, LONG_TIMEOUT, 0, 1, 0},
|
||||||
|
{ "default-week-format", OPT_DEFAULT_WEEK_FORMAT,
|
||||||
|
"The default week format used by WEEK() functions.",
|
||||||
|
(gptr*) &global_system_variables.default_week_format,
|
||||||
|
(gptr*) &max_system_variables.default_week_format,
|
||||||
|
0, GET_ULONG, REQUIRED_ARG, 0, 0, 3L, 0, 1, 0},
|
||||||
{0, 0, 0, 0, 0, 0, GET_NO_ARG, NO_ARG, 0, 0, 0, 0, 0, 0}
|
{0, 0, 0, 0, 0, 0, GET_NO_ARG, NO_ARG, 0, 0, 0, 0, 0, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -296,6 +296,8 @@ static sys_var_slave_skip_counter sys_slave_skip_counter("sql_slave_skip_counter
|
|||||||
static sys_var_rand_seed1 sys_rand_seed1("rand_seed1");
|
static sys_var_rand_seed1 sys_rand_seed1("rand_seed1");
|
||||||
static sys_var_rand_seed2 sys_rand_seed2("rand_seed2");
|
static sys_var_rand_seed2 sys_rand_seed2("rand_seed2");
|
||||||
|
|
||||||
|
static sys_var_thd_ulong sys_default_week_format("default_week_format",
|
||||||
|
&SV::default_week_format);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
List of all variables for initialisation and storage in hash
|
List of all variables for initialisation and storage in hash
|
||||||
@ -316,6 +318,7 @@ sys_var *sys_variables[]=
|
|||||||
&sys_bulk_insert_buff_size,
|
&sys_bulk_insert_buff_size,
|
||||||
&sys_concurrent_insert,
|
&sys_concurrent_insert,
|
||||||
&sys_connect_timeout,
|
&sys_connect_timeout,
|
||||||
|
&sys_default_week_format,
|
||||||
&sys_convert_charset,
|
&sys_convert_charset,
|
||||||
&sys_delay_key_write,
|
&sys_delay_key_write,
|
||||||
&sys_delayed_insert_limit,
|
&sys_delayed_insert_limit,
|
||||||
@ -421,6 +424,7 @@ struct show_var_st init_vars[]= {
|
|||||||
{sys_connect_timeout.name, (char*) &sys_connect_timeout, SHOW_SYS},
|
{sys_connect_timeout.name, (char*) &sys_connect_timeout, SHOW_SYS},
|
||||||
{sys_convert_charset.name, (char*) &sys_convert_charset, SHOW_SYS},
|
{sys_convert_charset.name, (char*) &sys_convert_charset, SHOW_SYS},
|
||||||
{"datadir", mysql_real_data_home, SHOW_CHAR},
|
{"datadir", mysql_real_data_home, SHOW_CHAR},
|
||||||
|
{"default_week_format", (char*) &sys_default_week_format, SHOW_SYS},
|
||||||
{sys_delay_key_write.name, (char*) &sys_delay_key_write, SHOW_SYS},
|
{sys_delay_key_write.name, (char*) &sys_delay_key_write, SHOW_SYS},
|
||||||
{sys_delayed_insert_limit.name, (char*) &sys_delayed_insert_limit,SHOW_SYS},
|
{sys_delayed_insert_limit.name, (char*) &sys_delayed_insert_limit,SHOW_SYS},
|
||||||
{sys_delayed_insert_timeout.name, (char*) &sys_delayed_insert_timeout, SHOW_SYS},
|
{sys_delayed_insert_timeout.name, (char*) &sys_delayed_insert_timeout, SHOW_SYS},
|
||||||
|
@ -309,6 +309,7 @@ struct system_variables
|
|||||||
ulong tmp_table_size;
|
ulong tmp_table_size;
|
||||||
ulong tx_isolation;
|
ulong tx_isolation;
|
||||||
ulong table_type;
|
ulong table_type;
|
||||||
|
ulong default_week_format;
|
||||||
|
|
||||||
my_bool log_warnings;
|
my_bool log_warnings;
|
||||||
my_bool low_priority_updates;
|
my_bool low_priority_updates;
|
||||||
|
@ -2002,7 +2002,11 @@ simple_expr:
|
|||||||
| USER '(' ')'
|
| USER '(' ')'
|
||||||
{ $$= new Item_func_user(); current_thd->safe_to_cache_query=0; }
|
{ $$= new Item_func_user(); current_thd->safe_to_cache_query=0; }
|
||||||
| WEEK_SYM '(' expr ')'
|
| WEEK_SYM '(' expr ')'
|
||||||
{ $$= new Item_func_week($3,new Item_int((char*) "0",0,1)); }
|
{
|
||||||
|
LEX *lex=Lex;
|
||||||
|
$$= new Item_func_week($3,new Item_int((char*) "0",
|
||||||
|
lex->thd->variables.default_week_format,1));
|
||||||
|
}
|
||||||
| WEEK_SYM '(' expr ',' expr ')'
|
| WEEK_SYM '(' expr ',' expr ')'
|
||||||
{ $$= new Item_func_week($3,$5); }
|
{ $$= new Item_func_week($3,$5); }
|
||||||
| YEAR_SYM '(' expr ')'
|
| YEAR_SYM '(' expr ')'
|
||||||
|
Reference in New Issue
Block a user