mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Merge rolltop.ignatz42.dyndns.org:/mnt/storeage/mysql-4.1-maint_20328
into rolltop.ignatz42.dyndns.org:/mnt/storeage/mysql-5.0-merge sql/item_timefunc.cc: Auto merged sql/slave.cc: Auto merged mysql-test/r/func_time.result: manual merge mysql-test/r/mysql_client.result: manual merge mysql-test/t/func_time.test: manual merge mysql-test/t/mysql_client.test: manual merge sql/sql_acl.cc: manual merge
This commit is contained in:
@ -891,6 +891,27 @@ t1 CREATE TABLE `t1` (
|
|||||||
`from_unixtime(1) + 0` double(23,6) default NULL
|
`from_unixtime(1) + 0` double(23,6) default NULL
|
||||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
(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);
|
||||||
|
H
|
||||||
|
120
|
||||||
|
(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);
|
||||||
|
H
|
||||||
|
120
|
||||||
|
(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);
|
||||||
|
H
|
||||||
|
05
|
||||||
|
(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);
|
||||||
|
H
|
||||||
|
5
|
||||||
|
End of 4.1 tests
|
||||||
explain extended select timestampdiff(SQL_TSI_WEEK, '2001-02-01', '2001-05-01') as a1,
|
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;
|
timestampdiff(SQL_TSI_FRAC_SECOND, '2001-02-01 12:59:59.120000', '2001-05-01 12:58:58.119999') as a2;
|
||||||
id select_type table type possible_keys key key_len ref rows Extra
|
id select_type table type possible_keys key key_len ref rows Extra
|
||||||
|
@ -2,54 +2,6 @@
|
|||||||
1
|
1
|
||||||
ERROR 1064 (42000) at line 3: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1
|
ERROR 1064 (42000) at line 3: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1
|
||||||
ERROR at line 1: USE must be followed by a database name
|
ERROR at line 1: USE must be followed by a database name
|
||||||
? (\?) Synonym for `help'.
|
|
||||||
clear (\c) Clear command.
|
|
||||||
connect (\r) Reconnect to the server. Optional arguments are db and host.
|
|
||||||
delimiter (\d) Set statement delimiter. NOTE: Takes the rest of the line as new delimiter.
|
|
||||||
edit (\e) Edit command with $EDITOR.
|
|
||||||
ego (\G) Send command to mysql server, display result vertically.
|
|
||||||
exit (\q) Exit mysql. Same as quit.
|
|
||||||
go (\g) Send command to mysql server.
|
|
||||||
help (\h) Display this help.
|
|
||||||
nopager (\n) Disable pager, print to stdout.
|
|
||||||
notee (\t) Don't write into outfile.
|
|
||||||
pager (\P) Set PAGER [to_pager]. Print the query results via PAGER.
|
|
||||||
print (\p) Print current command.
|
|
||||||
prompt (\R) Change your mysql prompt.
|
|
||||||
quit (\q) Quit mysql.
|
|
||||||
rehash (\#) Rebuild completion hash.
|
|
||||||
source (\.) Execute an SQL script file. Takes a file name as an argument.
|
|
||||||
status (\s) Get status information from the server.
|
|
||||||
system (\!) Execute a system shell command.
|
|
||||||
tee (\T) Set outfile [to_outfile]. Append everything into given outfile.
|
|
||||||
use (\u) Use another database. Takes database name as argument.
|
|
||||||
charset (\C) Switch to another charset. Might be needed for processing binlog with multi-byte charsets.
|
|
||||||
warnings (\W) Show warnings after every statement.
|
|
||||||
nowarning (\w) Don't show warnings after every statement.
|
|
||||||
? (\?) Synonym for `help'.
|
|
||||||
clear (\c) Clear command.
|
|
||||||
connect (\r) Reconnect to the server. Optional arguments are db and host.
|
|
||||||
delimiter (\d) Set statement delimiter. NOTE: Takes the rest of the line as new delimiter.
|
|
||||||
edit (\e) Edit command with $EDITOR.
|
|
||||||
ego (\G) Send command to mysql server, display result vertically.
|
|
||||||
exit (\q) Exit mysql. Same as quit.
|
|
||||||
go (\g) Send command to mysql server.
|
|
||||||
help (\h) Display this help.
|
|
||||||
nopager (\n) Disable pager, print to stdout.
|
|
||||||
notee (\t) Don't write into outfile.
|
|
||||||
pager (\P) Set PAGER [to_pager]. Print the query results via PAGER.
|
|
||||||
print (\p) Print current command.
|
|
||||||
prompt (\R) Change your mysql prompt.
|
|
||||||
quit (\q) Quit mysql.
|
|
||||||
rehash (\#) Rebuild completion hash.
|
|
||||||
source (\.) Execute an SQL script file. Takes a file name as an argument.
|
|
||||||
status (\s) Get status information from the server.
|
|
||||||
system (\!) Execute a system shell command.
|
|
||||||
tee (\T) Set outfile [to_outfile]. Append everything into given outfile.
|
|
||||||
use (\u) Use another database. Takes database name as argument.
|
|
||||||
charset (\C) Switch to another charset. Might be needed for processing binlog with multi-byte charsets.
|
|
||||||
warnings (\W) Show warnings after every statement.
|
|
||||||
nowarning (\w) Don't show warnings after every statement.
|
|
||||||
\
|
\
|
||||||
\\
|
\\
|
||||||
';
|
';
|
||||||
|
@ -446,7 +446,25 @@ create table t1 select now() - now(), curtime() - curtime(),
|
|||||||
show create table t1;
|
show create table t1;
|
||||||
drop table t1;
|
drop table t1;
|
||||||
|
|
||||||
# End of 4.1 tests
|
#
|
||||||
|
# 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);
|
||||||
|
|
||||||
|
--echo End of 4.1 tests
|
||||||
|
|
||||||
explain extended select timestampdiff(SQL_TSI_WEEK, '2001-02-01', '2001-05-01') as a1,
|
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;
|
timestampdiff(SQL_TSI_FRAC_SECOND, '2001-02-01 12:59:59.120000', '2001-05-01 12:58:58.119999') as a2;
|
||||||
|
@ -29,10 +29,9 @@
|
|||||||
--exec $MYSQL < $MYSQLTEST_VARDIR/tmp/bug20432.sql 2>&1
|
--exec $MYSQL < $MYSQLTEST_VARDIR/tmp/bug20432.sql 2>&1
|
||||||
|
|
||||||
#
|
#
|
||||||
# Bug #20328: mysql client interprets commands in comments
|
# Bug #20328: mysql client: dumb about trailing spaces on 'help' command
|
||||||
#
|
--exec echo 'help' | $MYSQL > $MYSQLTEST_VARDIR/tmp/bug20328.tmp
|
||||||
--exec echo 'help' | $MYSQL
|
--exec echo 'help ' | $MYSQL > $MYSQLTEST_VARDIR/tmp/bug20328.tmp
|
||||||
--exec echo 'help ' | $MYSQL
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Bug #20103: Escaping with backslash does not work
|
# Bug #20103: Escaping with backslash does not work
|
||||||
|
@ -1704,14 +1704,12 @@ uint Item_func_date_format::format_length(const String *format)
|
|||||||
case 'u': /* week (00..52), where week starts with Monday */
|
case 'u': /* week (00..52), where week starts with Monday */
|
||||||
case 'V': /* week 1..53 used with 'x' */
|
case 'V': /* week 1..53 used with 'x' */
|
||||||
case 'v': /* week 1..53 used with 'x', where week starts with Monday */
|
case 'v': /* week 1..53 used with 'x', where week starts with Monday */
|
||||||
case 'H': /* hour (00..23) */
|
|
||||||
case 'y': /* year, numeric, 2 digits */
|
case 'y': /* year, numeric, 2 digits */
|
||||||
case 'm': /* month, numeric */
|
case 'm': /* month, numeric */
|
||||||
case 'd': /* day (of the month), numeric */
|
case 'd': /* day (of the month), numeric */
|
||||||
case 'h': /* hour (01..12) */
|
case 'h': /* hour (01..12) */
|
||||||
case 'I': /* --||-- */
|
case 'I': /* --||-- */
|
||||||
case 'i': /* minutes, numeric */
|
case 'i': /* minutes, numeric */
|
||||||
case 'k': /* hour ( 0..23) */
|
|
||||||
case 'l': /* hour ( 1..12) */
|
case 'l': /* hour ( 1..12) */
|
||||||
case 'p': /* locale's AM or PM */
|
case 'p': /* locale's AM or PM */
|
||||||
case 'S': /* second (00..61) */
|
case 'S': /* second (00..61) */
|
||||||
@ -1720,6 +1718,10 @@ uint Item_func_date_format::format_length(const String *format)
|
|||||||
case 'e': /* day (0..31) */
|
case 'e': /* day (0..31) */
|
||||||
size += 2;
|
size += 2;
|
||||||
break;
|
break;
|
||||||
|
case 'k': /* hour ( 0..23) */
|
||||||
|
case 'H': /* hour (00..23; value > 23 OK, padding always 2-digit) */
|
||||||
|
size += 7; /* docs allow > 23, range depends on sizeof(unsigned int) */
|
||||||
|
break;
|
||||||
case 'r': /* time, 12-hour (hh:mm:ss [AP]M) */
|
case 'r': /* time, 12-hour (hh:mm:ss [AP]M) */
|
||||||
size += 11;
|
size += 11;
|
||||||
break;
|
break;
|
||||||
|
@ -3226,7 +3226,7 @@ static int exec_relay_log_event(THD* thd, RELAY_LOG_INFO* rli)
|
|||||||
rli->is_until_satisfied())
|
rli->is_until_satisfied())
|
||||||
{
|
{
|
||||||
char buf[22];
|
char buf[22];
|
||||||
sql_print_error("Slave SQL thread stopped because it reached its"
|
sql_print_information("Slave SQL thread stopped because it reached its"
|
||||||
" UNTIL position %s", llstr(rli->until_pos(), buf));
|
" UNTIL position %s", llstr(rli->until_pos(), buf));
|
||||||
/*
|
/*
|
||||||
Setting abort_slave flag because we do not want additional message about
|
Setting abort_slave flag because we do not want additional message about
|
||||||
|
@ -4693,6 +4693,32 @@ int open_grant_tables(THD *thd, TABLE_LIST *tables)
|
|||||||
DBUG_RETURN(0);
|
DBUG_RETURN(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ACL_USER *check_acl_user(LEX_USER *user_name,
|
||||||
|
uint *acl_acl_userdx)
|
||||||
|
{
|
||||||
|
ACL_USER *acl_user= 0;
|
||||||
|
uint counter;
|
||||||
|
|
||||||
|
safe_mutex_assert_owner(&acl_cache->lock);
|
||||||
|
|
||||||
|
for (counter= 0 ; counter < acl_users.elements ; counter++)
|
||||||
|
{
|
||||||
|
const char *user,*host;
|
||||||
|
acl_user= dynamic_element(&acl_users, counter, ACL_USER*);
|
||||||
|
if (!(user=acl_user->user))
|
||||||
|
user= "";
|
||||||
|
if (!(host=acl_user->host.hostname))
|
||||||
|
host= "";
|
||||||
|
if (!strcmp(user_name->user.str,user) &&
|
||||||
|
!my_strcasecmp(system_charset_info, user_name->host.str, host))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (counter == acl_users.elements)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
*acl_acl_userdx= counter;
|
||||||
|
return acl_user;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Modify a privilege table.
|
Modify a privilege table.
|
||||||
@ -4741,7 +4767,6 @@ static int modify_grant_table(TABLE *table, Field *host_field,
|
|||||||
DBUG_RETURN(error);
|
DBUG_RETURN(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Handle a privilege table.
|
Handle a privilege table.
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user