mirror of
https://github.com/MariaDB/server.git
synced 2025-01-21 22:34:18 +01:00
6e69536956
Problem 1: tests often fail in pushbuild with a timeout when waiting for the slave to start/stop/receive error. Fix 1: Updated the wait_for_slave_* macros in the following way: - The timeout is increased by a factor ten - Refactored the macros so that wait_for_slave_param does the work for the other macros. Problem 2: Tests are often incorrectly written, lacking a source include/wait_for_slave_to_[start|stop].inc. Fix 2: Improved the chance to get it right by adding include/start_slave.inc and include/stop_slave.inc, and updated tests to use these. Problem 3: The the built-in test language command wait_for_slave_to_stop is a misnomer (does not wait for the slave io thread) and does not give as much debug info in case of failure as the otherwise equivalent macro source include/wait_for_slave_sql_to_stop.inc Fix 3: Replaced all calls to the built-in command by a call to the macro. Problem 4: Some, but not all, of the wait_for_slave_* macros had an implicit connection slave. This made some tests confusing to read, and made it more difficult to use the macro in circular replication scenarios, where the connection named master needs to wait. Fix 4: Removed the implicit connection slave from all wait_for_slave_* macros, and updated tests to use an explicit connection slave where necessary. Problem 5: The macros wait_slave_status.inc and wait_show_pattern.inc were unused. Moreover, using them is difficult and error-prone. Fix 5: remove these macros. Problem 6: log_bin_trust_function_creators_basic failed when running tests because it assumed @@global.log_bin_trust_function_creators=1, and some tests modified this variable without resetting it to its original value. Fix 6: All tests that use this variable have been updated so that they reset the value at end of test. mysql-test/extra/rpl_tests/rpl_extraMaster_Col.test: Replaced wait_for_slave_to_stop by include/wait_for_slave_sql_to_stop.inc mysql-test/extra/rpl_tests/rpl_extraSlave_Col.test: Replaced wait_for_slave_to_stop by include/wait_for_slave_sql_to_stop.inc Added connection slave since includ/wait_for_slave_sql_to_stop.inc does not do that anymore. mysql-test/extra/rpl_tests/rpl_log.test: Replaced start slave+wait_slave_status by start_slave.inc mysql-test/include/reset_master_and_slave.inc: replaced start/stop slave by start_slave.inc/stop_slave.inc mysql-test/include/sync_slave_io_with_master.inc: Improved comments and error message. mysql-test/include/wait_for_slave_io_to_stop.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_for_slave_param.inc: - Improved usage instructions - Added more debug info in case of timeout - Added parameters $slave_param_comparison, $slave_timeout, $slave_keep_connection, $slave_error_message mysql-test/include/wait_for_slave_sql_error.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_for_slave_sql_to_start.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_for_slave_sql_to_stop.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_for_slave_to_start.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_for_slave_to_stop.inc: Refactored to use wait_for_slave_param.inc. Removed connection slave. mysql-test/include/wait_show_pattern.inc: Removed unused (and error-prone) file mysql-test/include/wait_slave_status.inc: Removed unused (and error-prone) file mysql-test/suite/binlog/t/binlog_auto_increment_bug33029.test: Renamed $keep_connection to $slave_keep_connection. mysql-test/suite/rpl/t/rpl_bug26395.test: Replace stop slave by stop_slave.inc mysql-test/suite/rpl/t/rpl_circular_for_4_hosts.test: Replace start/stop slave by start_slave.inc/stop_slave.inc. Replace wait_for_slave_param by wait_for_slave_sql_to_stop.inc. mysql-test/suite/rpl/t/rpl_dual_pos_advance.test: Renamed $keep_connection to $slave_keep_connection. mysql-test/suite/rpl/t/rpl_flushlog_loop.test: Replace wait_slave_status by start_slave.inc mysql-test/suite/rpl/t/rpl_idempotency.test: Added connection slave since wait_for_slave_sql_to_stop.inc does not do that any more. mysql-test/suite/rpl/t/rpl_incident.test: Replaced wait_for_slave_to_stop by wait_for_slave_sql_to_stop.inc mysql-test/suite/rpl/t/rpl_init_slave.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. Replaced save_master_pos;connection slave;sync_with_master by sync_slave_with_master. mysql-test/suite/rpl/t/rpl_log_pos.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. Replaced wait_for_slave_param by other wait_for_slave_* macros. mysql-test/suite/rpl/t/rpl_packet.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_row_inexist_tbl.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_row_stop_middle_update.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_row_until.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. Replaced save_master_pos;connection slave;sync_with_master by sync_slave_with_master. mysql-test/suite/rpl/t/rpl_server_id1.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_slave_grp_exec.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_slave_skip.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_slave_status.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/suite/rpl/t/rpl_sp.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/suite/rpl/t/rpl_sp_effects.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/suite/rpl/t/rpl_stm_until.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. Replaced save_master_pos;connection slave;sync_with_master by sync_slave_with_master. mysql-test/suite/rpl_ndb/t/rpl_ndb_basic.test: Replaced start slave by start_slave.inc. Added explicit connection slave since wait_for_slave_sql_to_stop.inc does not do that anymore. mysql-test/t/disabled.def: Disabled failing test. mysql-test/t/func_time.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/grant.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/grant2.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/innodb_notembedded.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/log_bin_trust_function_creators_func.test: Restore @@global.log_bin_trust_function_creators at end of test. Clean up at end of test by dropping the created user. mysql-test/t/query_cache.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/query_cache_notembedded.test: Restore @@global.log_bin_trust_function_creators at end of test. mysql-test/t/rpl_init_slave_func.test: Replaced start/stop slave by start_slave.inc/stop_slave.inc. mysql-test/t/timezone2.test: Restore @@global.log_bin_trust_function_creators at end of test.
832 lines
35 KiB
Text
832 lines
35 KiB
Text
#
|
|
# time functions
|
|
#
|
|
--disable_warnings
|
|
drop table if exists t1,t2,t3;
|
|
--enable_warnings
|
|
|
|
# Set timezone to GMT-3, to make it possible to use "interval 3 hour"
|
|
set time_zone="+03:00";
|
|
|
|
select from_days(to_days("960101")),to_days(960201)-to_days("19960101"),to_days(date_add(curdate(), interval 1 day))-to_days(curdate()),weekday("1997-11-29");
|
|
select period_add("9602",-12),period_diff(199505,"9404") ;
|
|
|
|
select now()-now(),weekday(curdate())-weekday(now()),unix_timestamp()-unix_timestamp(now());
|
|
select from_unixtime(unix_timestamp("1994-03-02 10:11:12")),from_unixtime(unix_timestamp("1994-03-02 10:11:12"),"%Y-%m-%d %h:%i:%s"),from_unixtime(unix_timestamp("1994-03-02 10:11:12"))+0;
|
|
select sec_to_time(9001),sec_to_time(9001)+0,time_to_sec("15:12:22"),
|
|
sec_to_time(time_to_sec("0:30:47")/6.21);
|
|
select sec_to_time(time_to_sec('-838:59:59'));
|
|
select now()-curdate()*1000000-curtime();
|
|
select strcmp(current_timestamp(),concat(current_date()," ",current_time()));
|
|
select strcmp(localtime(),concat(current_date()," ",current_time()));
|
|
select strcmp(localtimestamp(),concat(current_date()," ",current_time()));
|
|
select date_format("1997-01-02 03:04:05", "%M %W %D %Y %y %m %d %h %i %s %w");
|
|
select date_format("1997-01-02", concat("%M %W %D ","%Y %y %m %d %h %i %s %w"));
|
|
select dayofmonth("1997-01-02"),dayofmonth(19970323);
|
|
select month("1997-01-02"),year("98-02-03"),dayofyear("1997-12-31");
|
|
select month("2001-02-00"),year("2001-00-00");
|
|
select DAYOFYEAR("1997-03-03"), WEEK("1998-03-03"), QUARTER(980303);
|
|
select HOUR("1997-03-03 23:03:22"), MINUTE("23:03:22"), SECOND(230322);
|
|
|
|
# Test of week and yearweek
|
|
select week(19980101),week(19970101),week(19980101,1),week(19970101,1);
|
|
select week(19981231),week(19971231),week(19981231,1),week(19971231,1);
|
|
select week(19950101),week(19950101,1);
|
|
select yearweek('1981-12-31',1),yearweek('1982-01-01',1),yearweek('1982-12-31',1),yearweek('1983-01-01',1);
|
|
select yearweek('1987-01-01',1),yearweek('1987-01-01');
|
|
select week("2000-01-01",0) as '2000', week("2001-01-01",0) as '2001', week("2002-01-01",0) as '2002',week("2003-01-01",0) as '2003', week("2004-01-01",0) as '2004', week("2005-01-01",0) as '2005', week("2006-01-01",0) as '2006';
|
|
select week("2000-01-06",0) as '2000', week("2001-01-06",0) as '2001', week("2002-01-06",0) as '2002',week("2003-01-06",0) as '2003', week("2004-01-06",0) as '2004', week("2005-01-06",0) as '2005', week("2006-01-06",0) as '2006';
|
|
select week("2000-01-01",1) as '2000', week("2001-01-01",1) as '2001', week("2002-01-01",1) as '2002',week("2003-01-01",1) as '2003', week("2004-01-01",1) as '2004', week("2005-01-01",1) as '2005', week("2006-01-01",1) as '2006';
|
|
select week("2000-01-06",1) as '2000', week("2001-01-06",1) as '2001', week("2002-01-06",1) as '2002',week("2003-01-06",1) as '2003', week("2004-01-06",1) as '2004', week("2005-01-06",1) as '2005', week("2006-01-06",1) as '2006';
|
|
select yearweek("2000-01-01",0) as '2000', yearweek("2001-01-01",0) as '2001', yearweek("2002-01-01",0) as '2002',yearweek("2003-01-01",0) as '2003', yearweek("2004-01-01",0) as '2004', yearweek("2005-01-01",0) as '2005', yearweek("2006-01-01",0) as '2006';
|
|
select yearweek("2000-01-06",0) as '2000', yearweek("2001-01-06",0) as '2001', yearweek("2002-01-06",0) as '2002',yearweek("2003-01-06",0) as '2003', yearweek("2004-01-06",0) as '2004', yearweek("2005-01-06",0) as '2005', yearweek("2006-01-06",0) as '2006';
|
|
select yearweek("2000-01-01",1) as '2000', yearweek("2001-01-01",1) as '2001', yearweek("2002-01-01",1) as '2002',yearweek("2003-01-01",1) as '2003', yearweek("2004-01-01",1) as '2004', yearweek("2005-01-01",1) as '2005', yearweek("2006-01-01",1) as '2006';
|
|
select yearweek("2000-01-06",1) as '2000', yearweek("2001-01-06",1) as '2001', yearweek("2002-01-06",1) as '2002',yearweek("2003-01-06",1) as '2003', yearweek("2004-01-06",1) as '2004', yearweek("2005-01-06",1) as '2005', yearweek("2006-01-06",1) as '2006';
|
|
select week(19981231,2), week(19981231,3), week(20000101,2), week(20000101,3);
|
|
select week(20001231,2),week(20001231,3);
|
|
|
|
select week(19981231,0) as '0', week(19981231,1) as '1', week(19981231,2) as '2', week(19981231,3) as '3', week(19981231,4) as '4', week(19981231,5) as '5', week(19981231,6) as '6', week(19981231,7) as '7';
|
|
select week(20000101,0) as '0', week(20000101,1) as '1', week(20000101,2) as '2', week(20000101,3) as '3', week(20000101,4) as '4', week(20000101,5) as '5', week(20000101,6) as '6', week(20000101,7) as '7';
|
|
select week(20000106,0) as '0', week(20000106,1) as '1', week(20000106,2) as '2', week(20000106,3) as '3', week(20000106,4) as '4', week(20000106,5) as '5', week(20000106,6) as '6', week(20000106,7) as '7';
|
|
select week(20001231,0) as '0', week(20001231,1) as '1', week(20001231,2) as '2', week(20001231,3) as '3', week(20001231,4) as '4', week(20001231,5) as '5', week(20001231,6) as '6', week(20001231,7) as '7';
|
|
select week(20010101,0) as '0', week(20010101,1) as '1', week(20010101,2) as '2', week(20010101,3) as '3', week(20010101,4) as '4', week(20010101,5) as '5', week(20010101,6) as '6', week(20010101,7) as '7';
|
|
|
|
select yearweek(20001231,0), yearweek(20001231,1), yearweek(20001231,2), yearweek(20001231,3), yearweek(20001231,4), yearweek(20001231,5), yearweek(20001231,6), yearweek(20001231,7);
|
|
|
|
set default_week_format = 6;
|
|
select week(20001231), week(20001231,6);
|
|
set default_week_format = 0;
|
|
|
|
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('1999-12-31','%x-%v'),date_format('2000-01-01','%x-%v');
|
|
|
|
select dayname("1962-03-03"),dayname("1962-03-03")+0;
|
|
select monthname("1972-03-04"),monthname("1972-03-04")+0;
|
|
select time_format(19980131000000,'%H|%I|%k|%l|%i|%p|%r|%S|%T');
|
|
select time_format(19980131010203,'%H|%I|%k|%l|%i|%p|%r|%S|%T');
|
|
select time_format(19980131131415,'%H|%I|%k|%l|%i|%p|%r|%S|%T');
|
|
select time_format(19980131010015,'%H|%I|%k|%l|%i|%p|%r|%S|%T');
|
|
select date_format(concat('19980131',131415),'%H|%I|%k|%l|%i|%p|%r|%S|%T| %M|%W|%D|%Y|%y|%a|%b|%j|%m|%d|%h|%s|%w');
|
|
select date_format(19980021000000,'%H|%I|%k|%l|%i|%p|%r|%S|%T| %M|%W|%D|%Y|%y|%a|%b|%j|%m|%d|%h|%s|%w');
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 HOUR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 DAY);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 MONTH);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 1 YEAR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1:1" MINUTE_SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1:1" HOUR_MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1:1" DAY_HOUR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1 1" YEAR_MONTH);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1:1:1" HOUR_SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1 1:1" DAY_MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "1 1:1:1" DAY_SECOND);
|
|
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 SECOND);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 MINUTE);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 HOUR);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 DAY);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 MONTH);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL 1 YEAR);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1:1" MINUTE_SECOND);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1:1" HOUR_MINUTE);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1:1" DAY_HOUR);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1 1" YEAR_MONTH);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1:1:1" HOUR_SECOND);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1 1:1" DAY_MINUTE);
|
|
select date_sub("1998-01-01 00:00:00",INTERVAL "1 1:1:1" DAY_SECOND);
|
|
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 100000 SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL -100000 MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 100000 HOUR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL -100000 DAY);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL 100000 MONTH);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL -100000 YEAR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "10000:1" MINUTE_SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "-10000:1" HOUR_MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "10000:1" DAY_HOUR);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "-100 1" YEAR_MONTH);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "10000:99:99" HOUR_SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL " -10000 99:99" DAY_MINUTE);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL "10000 99:99:99" DAY_SECOND);
|
|
select "1997-12-31 23:59:59" + INTERVAL 1 SECOND;
|
|
select INTERVAL 1 DAY + "1997-12-31";
|
|
select "1998-01-01 00:00:00" - INTERVAL 1 SECOND;
|
|
|
|
select date_sub("1998-01-02",INTERVAL 31 DAY);
|
|
select date_add("1997-12-31",INTERVAL 1 SECOND);
|
|
select date_add("1997-12-31",INTERVAL 1 DAY);
|
|
select date_add(NULL,INTERVAL 100000 SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL NULL SECOND);
|
|
select date_add("1997-12-31 23:59:59",INTERVAL NULL MINUTE_SECOND);
|
|
select date_add("9999-12-31 23:59:59",INTERVAL 1 SECOND);
|
|
select date_sub("0000-00-00 00:00:00",INTERVAL 1 SECOND);
|
|
select date_add('1998-01-30',Interval 1 month);
|
|
select date_add('1998-01-30',Interval '2:1' year_month);
|
|
select date_add('1996-02-29',Interval '1' year);
|
|
select extract(YEAR FROM "1999-01-02 10:11:12");
|
|
select extract(YEAR_MONTH FROM "1999-01-02");
|
|
select extract(DAY FROM "1999-01-02");
|
|
select extract(DAY_HOUR FROM "1999-01-02 10:11:12");
|
|
select extract(DAY_MINUTE FROM "02 10:11:12");
|
|
select extract(DAY_SECOND FROM "225 10:11:12");
|
|
select extract(HOUR FROM "1999-01-02 10:11:12");
|
|
select extract(HOUR_MINUTE FROM "10:11:12");
|
|
select extract(HOUR_SECOND FROM "10:11:12");
|
|
select extract(MINUTE FROM "10:11:12");
|
|
select extract(MINUTE_SECOND FROM "10:11:12");
|
|
select extract(SECOND FROM "1999-01-02 10:11:12");
|
|
select extract(MONTH FROM "2001-02-00");
|
|
|
|
#
|
|
# test EXTRACT QUARTER (Bug #18100)
|
|
#
|
|
|
|
SELECT EXTRACT(QUARTER FROM '2004-01-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-02-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-03-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-04-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-05-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-06-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-07-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-08-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-09-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-10-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-11-15') AS quarter;
|
|
SELECT EXTRACT(QUARTER FROM '2004-12-15') AS quarter;
|
|
#
|
|
# MySQL Bugs: #12356: DATE_SUB or DATE_ADD incorrectly returns null
|
|
#
|
|
SELECT DATE_SUB(str_to_date('9999-12-31 00:01:00','%Y-%m-%d %H:%i:%s'), INTERVAL 1 MINUTE);
|
|
SELECT DATE_ADD(str_to_date('9999-12-30 23:59:00','%Y-%m-%d %H:%i:%s'), INTERVAL 1 MINUTE);
|
|
|
|
#
|
|
# Test big intervals (Bug #3498)
|
|
#
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 2147483648 SECOND;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL "1:2147483647" MINUTE_SECOND;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL "100000000:214748364700" MINUTE_SECOND;SELECT "1900-01-01 00:00:00" + INTERVAL 1<<37 SECOND;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 1<<31 MINUTE;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 1<<20 HOUR;
|
|
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 1<<38 SECOND;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 1<<33 MINUTE;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL 1<<30 HOUR;
|
|
SELECT "1900-01-01 00:00:00" + INTERVAL "1000000000:214748364700" MINUTE_SECOND;
|
|
|
|
#
|
|
# Bug #614 (multiple extracts in where)
|
|
#
|
|
|
|
create table t1 (ctime varchar(20));
|
|
insert into t1 values ('2001-01-12 12:23:40');
|
|
select ctime, hour(ctime) from t1;
|
|
select ctime from t1 where extract(MONTH FROM ctime) = 1 AND extract(YEAR FROM ctime) = 2001;
|
|
drop table t1;
|
|
|
|
#
|
|
# Test bug with monthname() and NULL
|
|
#
|
|
|
|
create table t1 (id int);
|
|
create table t2 (id int, date date);
|
|
insert into t1 values (1);
|
|
insert into t2 values (1, "0000-00-00");
|
|
insert into t1 values (2);
|
|
insert into t2 values (2, "2000-01-01");
|
|
select monthname(date) from t1 inner join t2 on t1.id = t2.id;
|
|
select monthname(date) from t1 inner join t2 on t1.id = t2.id order by t1.id;
|
|
drop table t1,t2;
|
|
|
|
#
|
|
# Test bug with month() and year() on text fields with wrong information
|
|
|
|
CREATE TABLE t1 (updated text) ENGINE=MyISAM;
|
|
INSERT INTO t1 VALUES ('');
|
|
SELECT month(updated) from t1;
|
|
SELECT year(updated) from t1;
|
|
drop table t1;
|
|
|
|
#
|
|
# Check that functions work identically on 0000-00-00 as a constant and on a
|
|
# column
|
|
#
|
|
|
|
create table t1 (d date, dt datetime, t timestamp, c char(10));
|
|
insert into t1 values ("0000-00-00", "0000-00-00", "0000-00-00", "0000-00-00");
|
|
select dayofyear("0000-00-00"),dayofyear(d),dayofyear(dt),dayofyear(t),dayofyear(c) from t1;
|
|
select dayofmonth("0000-00-00"),dayofmonth(d),dayofmonth(dt),dayofmonth(t),dayofmonth(c) from t1;
|
|
select month("0000-00-00"),month(d),month(dt),month(t),month(c) from t1;
|
|
select quarter("0000-00-00"),quarter(d),quarter(dt),quarter(t),quarter(c) from t1;
|
|
select week("0000-00-00"),week(d),week(dt),week(t),week(c) from t1;
|
|
select year("0000-00-00"),year(d),year(dt),year(t),year(c) from t1;
|
|
select yearweek("0000-00-00"),yearweek(d),yearweek(dt),yearweek(t),yearweek(c) from t1;
|
|
select to_days("0000-00-00"),to_days(d),to_days(dt),to_days(t),to_days(c) from t1;
|
|
select extract(MONTH FROM "0000-00-00"),extract(MONTH FROM d),extract(MONTH FROM dt),extract(MONTH FROM t),extract(MONTH FROM c) from t1;
|
|
drop table t1;
|
|
|
|
|
|
#
|
|
# Test problem with TIMESTAMP and BETWEEN
|
|
#
|
|
|
|
CREATE TABLE t1 ( start datetime default NULL);
|
|
INSERT INTO t1 VALUES ('2002-10-21 00:00:00'),('2002-10-28 00:00:00'),('2002-11-04 00:00:00');
|
|
CREATE TABLE t2 ( ctime1 timestamp NOT NULL, ctime2 timestamp NOT NULL);
|
|
INSERT INTO t2 VALUES (20021029165106,20021105164731);
|
|
CREATE TABLE t3 (ctime1 char(19) NOT NULL, ctime2 char(19) NOT NULL);
|
|
INSERT INTO t3 VALUES ("2002-10-29 16:51:06","2002-11-05 16:47:31");
|
|
|
|
# The following statement should be fixed to return a row in 4.1
|
|
select * from t1, t2 where t1.start between t2.ctime1 and t2.ctime2;
|
|
select * from t1, t2 where t1.start >= t2.ctime1 and t1.start <= t2.ctime2;
|
|
select * from t1, t3 where t1.start between t3.ctime1 and t3.ctime2;
|
|
drop table t1,t2,t3;
|
|
|
|
#
|
|
# Test unix timestamp
|
|
#
|
|
select @a:=FROM_UNIXTIME(1);
|
|
select unix_timestamp(@a);
|
|
select unix_timestamp('1969-12-01 19:00:01');
|
|
|
|
#
|
|
# Tests for bug #6439 "unix_timestamp() function returns wrong datetime
|
|
# values for too big argument", bug #7515 "from_unixtime(0) now
|
|
# returns NULL instead of the epoch" and bug #9191
|
|
# "TIMESTAMP/from_unixtime() no longer accepts 2^31-1."
|
|
# unix_timestamp() should return error for too big or negative argument.
|
|
# It should return Epoch value for zero argument since it seems that many
|
|
# users rely on this fact, from_unixtime() should work with values
|
|
# up to INT_MAX32 because of the same reason.
|
|
#
|
|
select from_unixtime(-1);
|
|
# check for from_unixtime(2^31-1) and from_unixtime(2^31)
|
|
select from_unixtime(2147483647);
|
|
select from_unixtime(2147483648);
|
|
select from_unixtime(0);
|
|
|
|
#
|
|
# Some more tests for bug #9191 "TIMESTAMP/from_unixtime() no
|
|
# longer accepts 2^31-1". Here we test that from_unixtime and
|
|
# unix_timestamp are consistent, when working with boundary dates.
|
|
#
|
|
select unix_timestamp(from_unixtime(2147483647));
|
|
select unix_timestamp(from_unixtime(2147483648));
|
|
|
|
# check for invalid dates
|
|
|
|
# bad year
|
|
select unix_timestamp('2039-01-20 01:00:00');
|
|
select unix_timestamp('1968-01-20 01:00:00');
|
|
# bad month
|
|
select unix_timestamp('2038-02-10 01:00:00');
|
|
select unix_timestamp('1969-11-20 01:00:00');
|
|
# bad day
|
|
select unix_timestamp('2038-01-20 01:00:00');
|
|
select unix_timestamp('1969-12-30 01:00:00');
|
|
|
|
#
|
|
# Check negative shift (we subtract several days for boundary dates during
|
|
# conversion).
|
|
select unix_timestamp('2038-01-17 12:00:00');
|
|
|
|
#
|
|
# Check positive shift. (it happens only on
|
|
# platfroms with unsigned time_t, such as QNX)
|
|
#
|
|
select unix_timestamp('1970-01-01 03:00:01');
|
|
|
|
# check bad date, close to the boundary (we cut them off in the very end)
|
|
select unix_timestamp('2038-01-19 07:14:07');
|
|
|
|
|
|
#
|
|
# Test types from + INTERVAL
|
|
#
|
|
|
|
CREATE TABLE t1 (datetime datetime, timestamp timestamp, date date, time time);
|
|
INSERT INTO t1 values ("2001-01-02 03:04:05", "2002-01-02 03:04:05", "2003-01-02", "06:07:08");
|
|
SELECT * from t1;
|
|
select date_add("1997-12-31",INTERVAL 1 SECOND);
|
|
select date_add("1997-12-31",INTERVAL "1 1" YEAR_MONTH);
|
|
|
|
select date_add(datetime, INTERVAL 1 SECOND) from t1;
|
|
select date_add(datetime, INTERVAL 1 YEAR) from t1;
|
|
|
|
select date_add(date,INTERVAL 1 SECOND) from t1;
|
|
select date_add(date,INTERVAL 1 MINUTE) from t1;
|
|
select date_add(date,INTERVAL 1 HOUR) from t1;
|
|
select date_add(date,INTERVAL 1 DAY) from t1;
|
|
select date_add(date,INTERVAL 1 MONTH) from t1;
|
|
select date_add(date,INTERVAL 1 YEAR) from t1;
|
|
select date_add(date,INTERVAL "1:1" MINUTE_SECOND) from t1;
|
|
select date_add(date,INTERVAL "1:1" HOUR_MINUTE) from t1;
|
|
select date_add(date,INTERVAL "1:1" DAY_HOUR) from t1;
|
|
select date_add(date,INTERVAL "1 1" YEAR_MONTH) from t1;
|
|
select date_add(date,INTERVAL "1:1:1" HOUR_SECOND) from t1;
|
|
select date_add(date,INTERVAL "1 1:1" DAY_MINUTE) from t1;
|
|
select date_add(date,INTERVAL "1 1:1:1" DAY_SECOND) from t1;
|
|
select date_add(date,INTERVAL "1" WEEK) from t1;
|
|
select date_add(date,INTERVAL "1" QUARTER) from t1;
|
|
select timestampadd(MINUTE, 1, date) from t1;
|
|
select timestampadd(WEEK, 1, date) from t1;
|
|
select timestampadd(SQL_TSI_SECOND, 1, date) from t1;
|
|
# mysqltest.c discards an expected 'deprecated' warning on prepare stage
|
|
--disable_ps_protocol
|
|
select timestampadd(SQL_TSI_FRAC_SECOND, 1, date) from t1;
|
|
--enable_ps_protocol
|
|
|
|
select timestampdiff(MONTH, '2001-02-01', '2001-05-01') as a;
|
|
select timestampdiff(YEAR, '2002-05-01', '2001-01-01') as a;
|
|
select timestampdiff(QUARTER, '2002-05-01', '2001-01-01') as a;
|
|
select timestampdiff(MONTH, '2000-03-28', '2000-02-29') as a;
|
|
select timestampdiff(MONTH, '1991-03-28', '2000-02-29') as a;
|
|
select timestampdiff(SQL_TSI_WEEK, '2001-02-01', '2001-05-01') as a;
|
|
select timestampdiff(SQL_TSI_HOUR, '2001-02-01', '2001-05-01') as a;
|
|
select timestampdiff(SQL_TSI_DAY, '2001-02-01', '2001-05-01') as a;
|
|
select timestampdiff(SQL_TSI_MINUTE, '2001-02-01 12:59:59', '2001-05-01 12:58:59') as a;
|
|
select timestampdiff(SQL_TSI_SECOND, '2001-02-01 12:59:59', '2001-05-01 12:58:58') as a;
|
|
# mysqltest.c discards an expected 'deprecated' warning on prepare stage
|
|
--disable_ps_protocol
|
|
select timestampdiff(SQL_TSI_FRAC_SECOND, '2001-02-01 12:59:59.120000', '2001-05-01 12:58:58.119999') as a;
|
|
--enable_ps_protocol
|
|
|
|
select timestampdiff(SQL_TSI_DAY, '1986-02-01', '1986-03-01') as a1,
|
|
timestampdiff(SQL_TSI_DAY, '1900-02-01', '1900-03-01') as a2,
|
|
timestampdiff(SQL_TSI_DAY, '1996-02-01', '1996-03-01') as a3,
|
|
timestampdiff(SQL_TSI_DAY, '2000-02-01', '2000-03-01') as a4;
|
|
|
|
# bug 16226
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-11 14:30:27');
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-11 14:30:28');
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-11 14:30:29');
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-12 14:30:27');
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-12 14:30:28');
|
|
SELECT TIMESTAMPDIFF(day,'2006-01-10 14:30:28','2006-01-12 14:30:29');
|
|
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-17 14:30:27');
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-17 14:30:28');
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-17 14:30:29');
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-24 14:30:27');
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-24 14:30:28');
|
|
SELECT TIMESTAMPDIFF(week,'2006-01-10 14:30:28','2006-01-24 14:30:29');
|
|
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-02-10 14:30:27');
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-02-10 14:30:28');
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-02-10 14:30:29');
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-03-10 14:30:27');
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-03-10 14:30:28');
|
|
SELECT TIMESTAMPDIFF(month,'2006-01-10 14:30:28','2006-03-10 14:30:29');
|
|
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2007-01-10 14:30:27');
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2007-01-10 14:30:28');
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2007-01-10 14:30:29');
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2008-01-10 14:30:27');
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2008-01-10 14:30:28');
|
|
SELECT TIMESTAMPDIFF(year,'2006-01-10 14:30:28','2008-01-10 14:30:29');
|
|
|
|
# end of bug
|
|
|
|
select date_add(time,INTERVAL 1 SECOND) from t1;
|
|
drop table t1;
|
|
|
|
# test for last_day
|
|
select last_day('2000-02-05') as f1, last_day('2002-12-31') as f2,
|
|
last_day('2003-03-32') as f3, last_day('2003-04-01') as f4,
|
|
last_day('2001-01-01 01:01:01') as f5, last_day(NULL),
|
|
last_day('2001-02-12');
|
|
|
|
create table t1 select last_day('2000-02-05') as a,
|
|
from_days(to_days("960101")) as b;
|
|
describe t1;
|
|
select * from t1;
|
|
drop table t1;
|
|
select last_day('2000-02-05') as a,
|
|
from_days(to_days("960101")) as b;
|
|
|
|
select date_add(last_day("1997-12-1"), INTERVAL 1 DAY);
|
|
select length(last_day("1997-12-1"));
|
|
select last_day("1997-12-1")+0;
|
|
select last_day("1997-12-1")+0.0;
|
|
|
|
# Test SAPDB UTC_% functions. This part is TZ dependant (It is supposed that
|
|
# TZ variable set to GMT-3
|
|
|
|
select strcmp(date_sub(localtimestamp(), interval 3 hour), utc_timestamp())=0;
|
|
select strcmp(date_format(date_sub(localtimestamp(), interval 3 hour),"%T"), utc_time())=0;
|
|
select strcmp(date_format(date_sub(localtimestamp(), interval 3 hour),"%Y-%m-%d"), utc_date())=0;
|
|
select strcmp(date_format(utc_timestamp(),"%T"), utc_time())=0;
|
|
select strcmp(date_format(utc_timestamp(),"%Y-%m-%d"), utc_date())=0;
|
|
select strcmp(concat(utc_date(),' ',utc_time()),utc_timestamp())=0;
|
|
|
|
explain extended select period_add("9602",-12),period_diff(199505,"9404"),from_days(to_days("960101")),dayofmonth("1997-01-02"), month("1997-01-02"), monthname("1972-03-04"),dayofyear("0000-00-00"),HOUR("1997-03-03 23:03:22"),MINUTE("23:03:22"),SECOND(230322),QUARTER(980303),WEEK("1998-03-03"),yearweek("2000-01-01",1),week(19950101,1),year("98-02-03"),weekday(curdate())-weekday(now()),dayname("1962-03-03"),unix_timestamp(),sec_to_time(time_to_sec("0:30:47")/6.21),curtime(),utc_time(),curdate(),utc_date(),utc_timestamp(),date_format("1997-01-02 03:04:05", "%M %W %D %Y %y %m %d %h %i %s %w"),from_unixtime(unix_timestamp("1994-03-02 10:11:12")),"1997-12-31 23:59:59" + INTERVAL 1 SECOND,"1998-01-01 00:00:00" - INTERVAL 1 SECOND,INTERVAL 1 DAY + "1997-12-31", extract(YEAR FROM "1999-01-02 10:11:12"),date_add("1997-12-31 23:59:59",INTERVAL 1 SECOND);
|
|
|
|
SET @TMP='2007-08-01 12:22:49';
|
|
CREATE TABLE t1 (d DATETIME);
|
|
INSERT INTO t1 VALUES ('2007-08-01 12:22:59');
|
|
INSERT INTO t1 VALUES ('2007-08-01 12:23:01');
|
|
INSERT INTO t1 VALUES ('2007-08-01 12:23:20');
|
|
SELECT count(*) FROM t1 WHERE d>FROM_DAYS(TO_DAYS(@TMP)) AND d<=FROM_DAYS(TO_DAYS(@TMP)+1);
|
|
DROP TABLE t1;
|
|
|
|
#
|
|
# Bug #10568
|
|
#
|
|
|
|
select last_day('2005-00-00');
|
|
select last_day('2005-00-01');
|
|
select last_day('2005-01-00');
|
|
|
|
#
|
|
# Bug #18501: monthname and NULLs
|
|
#
|
|
|
|
select monthname(str_to_date(null, '%m')), monthname(str_to_date(null, '%m')),
|
|
monthname(str_to_date(1, '%m')), monthname(str_to_date(0, '%m'));
|
|
|
|
#
|
|
# Bug #16327: problem with timestamp < 1970
|
|
#
|
|
|
|
set time_zone='-6:00';
|
|
create table t1(a timestamp);
|
|
insert into t1 values (19691231190001);
|
|
select * from t1;
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug#16377 result of DATE/TIME functions were compared as strings which
|
|
# can lead to a wrong result.
|
|
# Now wrong dates should be compared only with CAST()
|
|
create table t1(f1 date, f2 time, f3 datetime);
|
|
insert into t1 values ("2006-01-01", "12:01:01", "2006-01-01 12:01:01");
|
|
insert into t1 values ("2006-01-02", "12:01:02", "2006-01-02 12:01:02");
|
|
select f1 from t1 where f1 between CAST("2006-1-1" as date) and CAST(20060101 as date);
|
|
select f1 from t1 where f1 between cast("2006-1-1" as date) and cast("2006.1.1" as date);
|
|
select f1 from t1 where date(f1) between cast("2006-1-1" as date) and cast("2006.1.1" as date);
|
|
select f2 from t1 where f2 between cast("12:1:2" as time) and cast("12:2:2" as time);
|
|
select f2 from t1 where time(f2) between cast("12:1:2" as time) and cast("12:2:2" as time);
|
|
select f3 from t1 where f3 between cast("2006-1-1 12:1:1" as datetime) and cast("2006-1-1 12:1:2" as datetime);
|
|
select f3 from t1 where timestamp(f3) between cast("2006-1-1 12:1:1" as datetime) and cast("2006-1-1 12:1:2" as datetime);
|
|
select f1 from t1 where cast("2006-1-1" as date) between f1 and f3;
|
|
select f1 from t1 where cast("2006-1-1" as date) between date(f1) and date(f3);
|
|
select f1 from t1 where cast("2006-1-1" as date) between f1 and cast('zzz' as date);
|
|
select f1 from t1 where makedate(2006,1) between date(f1) and date(f3);
|
|
select f1 from t1 where makedate(2006,2) between date(f1) and date(f3);
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug #16546
|
|
#
|
|
|
|
create table t1 select now() - now(), curtime() - curtime(),
|
|
sec_to_time(1) + 0, from_unixtime(1) + 0;
|
|
show create table t1;
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug #11655: Wrong time is returning from nested selects - maximum time exists
|
|
#
|
|
# check if SEC_TO_TIME() handles out-of-range values correctly
|
|
SELECT SEC_TO_TIME(3300000);
|
|
SELECT SEC_TO_TIME(3300000)+0;
|
|
SELECT SEC_TO_TIME(3600 * 4294967296);
|
|
|
|
# check if TIME_TO_SEC() handles out-of-range values correctly
|
|
SELECT TIME_TO_SEC('916:40:00');
|
|
|
|
# check if ADDTIME() handles out-of-range values correctly
|
|
SELECT ADDTIME('500:00:00', '416:40:00');
|
|
SELECT ADDTIME('916:40:00', '416:40:00');
|
|
|
|
# check if SUBTIME() handles out-of-range values correctly
|
|
SELECT SUBTIME('916:40:00', '416:40:00');
|
|
SELECT SUBTIME('-916:40:00', '416:40:00');
|
|
|
|
# check if MAKETIME() handles out-of-range values correctly
|
|
SELECT MAKETIME(916,0,0);
|
|
SELECT MAKETIME(4294967296, 0, 0);
|
|
SELECT MAKETIME(-4294967296, 0, 0);
|
|
SELECT MAKETIME(0, 4294967296, 0);
|
|
SELECT MAKETIME(0, 0, 4294967296);
|
|
SELECT MAKETIME(CAST(-1 AS UNSIGNED), 0, 0);
|
|
|
|
# check if EXTRACT() handles out-of-range values correctly
|
|
SELECT EXTRACT(HOUR FROM '100000:02:03');
|
|
|
|
# check if we get proper warnings if both input string truncation
|
|
# and out-of-range value occur
|
|
CREATE TABLE t1(f1 TIME);
|
|
INSERT INTO t1 VALUES('916:00:00 a');
|
|
SELECT * FROM t1;
|
|
DROP TABLE t1;
|
|
|
|
#
|
|
# Bug #20927: sec_to_time treats big unsigned as signed
|
|
#
|
|
# check if SEC_TO_TIME() handles BIGINT UNSIGNED values correctly
|
|
SELECT SEC_TO_TIME(CAST(-1 AS UNSIGNED));
|
|
|
|
#
|
|
# 21913: DATE_FORMAT() Crashes mysql server if I use it through
|
|
# mysql-connector-j driver.
|
|
#
|
|
|
|
SET NAMES latin1;
|
|
SET character_set_results = NULL;
|
|
SHOW VARIABLES LIKE 'character_set_results';
|
|
|
|
CREATE TABLE testBug8868 (field1 DATE, field2 VARCHAR(32) CHARACTER SET BINARY);
|
|
INSERT INTO testBug8868 VALUES ('2006-09-04', 'abcd');
|
|
|
|
SELECT DATE_FORMAT(field1,'%b-%e %l:%i%p') as fmtddate, field2 FROM testBug8868;
|
|
|
|
DROP TABLE testBug8868;
|
|
|
|
SET NAMES DEFAULT;
|
|
|
|
#
|
|
# Bug #31160: MAKETIME() crashes server when returning NULL in ORDER BY using
|
|
# filesort
|
|
#
|
|
CREATE TABLE t1 (
|
|
a TIMESTAMP
|
|
);
|
|
INSERT INTO t1 VALUES (now()), (now());
|
|
SELECT 1 FROM t1 ORDER BY MAKETIME(1, 1, a);
|
|
DROP TABLE t1;
|
|
#
|
|
# Bug #19844 time_format in Union truncates values
|
|
#
|
|
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 DAY)),'%H') As H)
|
|
union
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 DAY)),'%H') As H);
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 DAY)),'%k') As H)
|
|
union
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 DAY)),'%k') As H);
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 HOUR)),'%H') As H)
|
|
union
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 HOUR)),'%H') As H);
|
|
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 HOUR)),'%k') As H)
|
|
union
|
|
(select time_format(timediff(now(), DATE_SUB(now(),INTERVAL 5 HOUR)),'%k') As H);
|
|
|
|
#
|
|
# Bug #23653: crash if last_day('0000-00-00')
|
|
#
|
|
|
|
select last_day('0000-00-00');
|
|
|
|
#
|
|
# Bug 23616: datetime functions with double argumets
|
|
#
|
|
|
|
select isnull(week(now() + 0)), isnull(week(now() + 0.2)),
|
|
week(20061108), week(20061108.01), week(20061108085411.000002);
|
|
|
|
--echo End of 4.1 tests
|
|
|
|
explain extended select timestampdiff(SQL_TSI_WEEK, '2001-02-01', '2001-05-01') as a1,
|
|
timestampdiff(SQL_TSI_FRAC_SECOND, '2001-02-01 12:59:59.120000', '2001-05-01 12:58:58.119999') as a2;
|
|
|
|
#
|
|
# Bug #10590: %h, %I, and %l format specifies should all return results in
|
|
# the 0-11 range
|
|
#
|
|
select time_format('100:00:00', '%H %k %h %I %l');
|
|
|
|
#
|
|
# Bug #12562: Make SYSDATE behave like it does in Oracle: always the current
|
|
# time, regardless of magic to make NOW() always the same for the
|
|
# entirety of a statement.
|
|
SET @old_log_bin_trust_function_creators= @@global.log_bin_trust_function_creators;
|
|
SET GLOBAL log_bin_trust_function_creators = 1;
|
|
|
|
create table t1 (a timestamp default '2005-05-05 01:01:01',
|
|
b timestamp default '2005-05-05 01:01:01');
|
|
delimiter //;
|
|
drop function if exists t_slow_sysdate;
|
|
create function t_slow_sysdate() returns timestamp
|
|
begin
|
|
do sleep(2);
|
|
return sysdate();
|
|
end;
|
|
//
|
|
|
|
insert into t1 set a = sysdate(), b = t_slow_sysdate();//
|
|
|
|
create trigger t_before before insert on t1
|
|
for each row begin
|
|
set new.b = t_slow_sysdate();
|
|
end
|
|
//
|
|
|
|
delimiter ;//
|
|
|
|
insert into t1 set a = sysdate();
|
|
|
|
select a != b from t1;
|
|
|
|
drop trigger t_before;
|
|
drop function t_slow_sysdate;
|
|
drop table t1;
|
|
|
|
SET GLOBAL log_bin_trust_function_creators = 0;
|
|
|
|
create table t1 (a datetime, i int, b datetime);
|
|
insert into t1 select sysdate(), sleep(1), sysdate() from dual;
|
|
select a != b from t1;
|
|
drop table t1;
|
|
|
|
delimiter //;
|
|
create procedure t_sysdate()
|
|
begin
|
|
select sysdate() into @a;
|
|
do sleep(2);
|
|
select sysdate() into @b;
|
|
select @a != @b;
|
|
end;
|
|
//
|
|
delimiter ;//
|
|
call t_sysdate();
|
|
drop procedure t_sysdate;
|
|
SET @@global.log_bin_trust_function_creators= @old_log_bin_trust_function_creators;
|
|
|
|
#
|
|
# Bug #13534: timestampdiff() returned incorrect results across leap years
|
|
#
|
|
select timestampdiff(month,'2004-09-11','2004-09-11');
|
|
select timestampdiff(month,'2004-09-11','2005-09-11');
|
|
select timestampdiff(month,'2004-09-11','2006-09-11');
|
|
select timestampdiff(month,'2004-09-11','2007-09-11');
|
|
select timestampdiff(month,'2005-09-11','2004-09-11');
|
|
select timestampdiff(month,'2005-09-11','2003-09-11');
|
|
|
|
select timestampdiff(month,'2004-02-28','2005-02-28');
|
|
select timestampdiff(month,'2004-02-29','2005-02-28');
|
|
select timestampdiff(month,'2004-02-28','2005-02-28');
|
|
select timestampdiff(month,'2004-03-29','2005-03-28');
|
|
select timestampdiff(month,'2003-02-28','2004-02-29');
|
|
select timestampdiff(month,'2003-02-28','2005-02-28');
|
|
|
|
select timestampdiff(month,'1999-09-11','2001-10-10');
|
|
select timestampdiff(month,'1999-09-11','2001-9-11');
|
|
|
|
select timestampdiff(year,'1999-09-11','2001-9-11');
|
|
select timestampdiff(year,'2004-02-28','2005-02-28');
|
|
select timestampdiff(year,'2004-02-29','2005-02-28');
|
|
|
|
#
|
|
# Bug #18618: BETWEEN for dates with the second argument being a constant
|
|
# expression and the first and the third arguments being fields
|
|
#
|
|
|
|
CREATE TABLE t1 (id int NOT NULL PRIMARY KEY, day date);
|
|
CREATE TABLE t2 (id int NOT NULL PRIMARY KEY, day date);
|
|
|
|
INSERT INTO t1 VALUES
|
|
(1, '2005-06-01'), (2, '2005-02-01'), (3, '2005-07-01');
|
|
INSERT INTO t2 VALUES
|
|
(1, '2005-08-01'), (2, '2005-06-15'), (3, '2005-07-15');
|
|
|
|
SELECT * FROM t1, t2
|
|
WHERE t1.day BETWEEN
|
|
'2005.09.01' - INTERVAL 6 MONTH AND t2.day;
|
|
SELECT * FROM t1, t2
|
|
WHERE CAST(t1.day AS DATE) BETWEEN
|
|
'2005.09.01' - INTERVAL 6 MONTH AND t2.day;
|
|
|
|
DROP TABLE t1,t2;
|
|
|
|
|
|
# Restore timezone to default
|
|
set time_zone= @@global.time_zone;
|
|
|
|
#
|
|
# Bug #22229: bug in DATE_ADD()
|
|
#
|
|
|
|
select str_to_date('10:00 PM', '%h:%i %p') + INTERVAL 10 MINUTE;
|
|
|
|
#
|
|
# Bug #21103: DATE column not compared as DATE
|
|
#
|
|
|
|
create table t1 (field DATE);
|
|
insert into t1 values ('2006-11-06');
|
|
select * from t1 where field < '2006-11-06 04:08:36.0';
|
|
select * from t1 where field = '2006-11-06 04:08:36.0';
|
|
select * from t1 where field = '2006-11-06';
|
|
select * from t1 where CAST(field as DATETIME) < '2006-11-06 04:08:36.0';
|
|
select * from t1 where CAST(field as DATE) < '2006-11-06 04:08:36.0';
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug #25643: SEC_TO_TIME function problem
|
|
#
|
|
CREATE TABLE t1 (a int, t1 time, t2 time, d date, PRIMARY KEY (a));
|
|
INSERT INTO t1 VALUES (1, '10:00:00', NULL, NULL),
|
|
(2, '11:00:00', '11:15:00', '1972-02-06');
|
|
SELECT t1, t2, SEC_TO_TIME( TIME_TO_SEC( t2 ) - TIME_TO_SEC( t1 ) ), QUARTER(d)
|
|
FROM t1;
|
|
SELECT t1, t2, SEC_TO_TIME( TIME_TO_SEC( t2 ) - TIME_TO_SEC( t1 ) ), QUARTER(d)
|
|
FROM t1 ORDER BY a DESC;
|
|
DROP TABLE t1;
|
|
|
|
#
|
|
# Bug #20293: group by cuts off value from time_format
|
|
#
|
|
# Check if using GROUP BY with TIME_FORMAT() produces correct results
|
|
|
|
SELECT TIME_FORMAT(SEC_TO_TIME(a),"%H:%i:%s") FROM (SELECT 3020399 AS a UNION SELECT 3020398 ) x GROUP BY 1;
|
|
|
|
#
|
|
# Bug#28875 Conversion between ASCII and LATIN1 charsets does not function
|
|
#
|
|
set names latin1;
|
|
create table t1 (a varchar(15) character set ascii not null);
|
|
insert into t1 values ('070514-000000');
|
|
# Conversion of date_format() result to ASCII
|
|
# is safe with the default locale en_US
|
|
--replace_column 1 #
|
|
select concat(a,ifnull(min(date_format(now(), '%Y-%m-%d')),' ull')) from t1;
|
|
# Error for swe7: it is not ASCII compatible
|
|
set names swe7;
|
|
--error 1267
|
|
select concat(a,ifnull(min(date_format(now(), '%Y-%m-%d')),' ull')) from t1;
|
|
set names latin1;
|
|
# Conversion of date_format() result to ASCII
|
|
# is not safe with the non-default locale fr_FR
|
|
# because month and day names can have accented characters
|
|
set lc_time_names=fr_FR;
|
|
--error 1267
|
|
select concat(a,ifnull(min(date_format(now(), '%Y-%m-%d')),' ull')) from t1;
|
|
set lc_time_names=en_US;
|
|
drop table t1;
|
|
|
|
#
|
|
# Bug#32180: DATE_ADD treats datetime numeric argument as DATE
|
|
# instead of DATETIME
|
|
#
|
|
|
|
select DATE_ADD('20071108181000', INTERVAL 1 DAY);
|
|
select DATE_ADD(20071108181000, INTERVAL 1 DAY);
|
|
select DATE_ADD('20071108', INTERVAL 1 DAY);
|
|
select DATE_ADD(20071108, INTERVAL 1 DAY);
|
|
|
|
#
|
|
# Bug#32770: LAST_DAY() returns a DATE, but somehow internally keeps
|
|
# track of the TIME.
|
|
#
|
|
|
|
select LAST_DAY('2007-12-06 08:59:19.05') - INTERVAL 1 SECOND;
|
|
|
|
#
|
|
# Bug#33834: FRAC_SECOND: Applicability not clear in documentation
|
|
#
|
|
# Show that he use of FRAC_SECOND, for anything other than
|
|
# TIMESTAMPADD / TIMESTAMPDIFF, is a server error.
|
|
|
|
# mysqltest.c discards an expected 'deprecated' warning on prepare stage
|
|
--disable_ps_protocol
|
|
SELECT TIMESTAMPADD(FRAC_SECOND, 1, '2008-02-18');
|
|
SELECT TIMESTAMPDIFF(FRAC_SECOND, '2008-02-17', '2008-02-18');
|
|
--enable_ps_protocol
|
|
|
|
--error ER_PARSE_ERROR
|
|
SELECT DATE_ADD('2008-02-18', INTERVAL 1 FRAC_SECOND);
|
|
--error ER_PARSE_ERROR
|
|
SELECT DATE_SUB('2008-02-18', INTERVAL 1 FRAC_SECOND);
|
|
|
|
--error ER_PARSE_ERROR
|
|
SELECT '2008-02-18' + INTERVAL 1 FRAC_SECOND;
|
|
--error ER_PARSE_ERROR
|
|
SELECT '2008-02-18' - INTERVAL 1 FRAC_SECOND;
|
|
|
|
--echo End of 5.0 tests
|
|
|
|
#
|
|
# Bug #18997
|
|
#
|
|
|
|
select date_sub("0050-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_sub("0199-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_add("0199-12-31 23:59:59",INTERVAL 2 SECOND);
|
|
select date_sub("0200-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_sub("0200-01-01 00:00:01",INTERVAL 1 SECOND);
|
|
select date_sub("0200-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_add("2001-01-01 23:59:59",INTERVAL -2000 YEAR);
|
|
select date_sub("50-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_sub("90-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_sub("0069-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
select date_sub("0169-01-01 00:00:01",INTERVAL 2 SECOND);
|
|
|
|
|
|
--echo End of 5.1 tests
|