Merge 10.0->10.0-connect
This commit is contained in:
commit
1b1ffe408c
@ -176,6 +176,81 @@ MARK_AS_ADVANCED(CYBOZU BACKUP_TEST WITHOUT_SERVER DISABLE_SHARED)
|
||||
|
||||
OPTION(NOT_FOR_DISTRIBUTION "Allow linking with GPLv2-incompatible system libraries. Only set it you never plan to distribute the resulting binaries" OFF)
|
||||
|
||||
include(CheckCSourceCompiles)
|
||||
include(CheckCXXSourceCompiles)
|
||||
# We need some extra FAIL_REGEX patterns
|
||||
# Note that CHECK_C_SOURCE_COMPILES is a misnomer, it will also link.
|
||||
MACRO (MY_CHECK_C_COMPILER_FLAG FLAG RESULT)
|
||||
SET(SAVE_CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS}")
|
||||
SET(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${FLAG}")
|
||||
CHECK_C_SOURCE_COMPILES("int main(void) { return 0; }" ${RESULT}
|
||||
FAIL_REGEX "argument unused during compilation"
|
||||
FAIL_REGEX "unsupported .*option"
|
||||
FAIL_REGEX "unknown .*option"
|
||||
FAIL_REGEX "unrecognized .*option"
|
||||
FAIL_REGEX "ignoring unknown option"
|
||||
FAIL_REGEX "[Ww]arning: [Oo]ption"
|
||||
)
|
||||
SET(CMAKE_REQUIRED_FLAGS "${SAVE_CMAKE_REQUIRED_FLAGS}")
|
||||
ENDMACRO()
|
||||
|
||||
MACRO (MY_CHECK_CXX_COMPILER_FLAG FLAG RESULT)
|
||||
SET(SAVE_CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS}")
|
||||
SET(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${FLAG}")
|
||||
CHECK_CXX_SOURCE_COMPILES("int main(void) { return 0; }" ${RESULT}
|
||||
FAIL_REGEX "argument unused during compilation"
|
||||
FAIL_REGEX "unsupported .*option"
|
||||
FAIL_REGEX "unknown .*option"
|
||||
FAIL_REGEX "unrecognized .*option"
|
||||
FAIL_REGEX "ignoring unknown option"
|
||||
FAIL_REGEX "[Ww]arning: [Oo]ption"
|
||||
)
|
||||
SET(CMAKE_REQUIRED_FLAGS "${SAVE_CMAKE_REQUIRED_FLAGS}")
|
||||
ENDMACRO()
|
||||
|
||||
OPTION(WITH_ASAN "Enable address sanitizer" OFF)
|
||||
IF (WITH_ASAN)
|
||||
# gcc 4.8.1 and new versions of clang
|
||||
MY_CHECK_C_COMPILER_FLAG("-fsanitize=address" HAVE_C_FSANITIZE)
|
||||
MY_CHECK_CXX_COMPILER_FLAG("-fsanitize=address" HAVE_CXX_FSANITIZE)
|
||||
|
||||
IF(HAVE_C_FSANITIZE AND HAVE_CXX_FSANITIZE)
|
||||
# We switch on basic optimization also for debug builds.
|
||||
# With optimization we may get some warnings, so we switch off -Werror
|
||||
SET(CMAKE_C_FLAGS_DEBUG
|
||||
"${CMAKE_C_FLAGS_DEBUG} -fsanitize=address -O1 -Wno-error -fPIC")
|
||||
SET(CMAKE_C_FLAGS_RELWITHDEBINFO
|
||||
"${CMAKE_C_FLAGS_RELWITHDEBINFO} -fsanitize=address -fPIC")
|
||||
SET(CMAKE_CXX_FLAGS_DEBUG
|
||||
"${CMAKE_CXX_FLAGS_DEBUG} -fsanitize=address -O1 -Wno-error -fPIC")
|
||||
SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO
|
||||
"${CMAKE_CXX_FLAGS_RELWITHDEBINFO} -fsanitize=address -fPIC")
|
||||
SET(WITH_ASAN_OK 1)
|
||||
ELSE()
|
||||
# older versions of clang
|
||||
MY_CHECK_C_COMPILER_FLAG("-faddress-sanitizer" HAVE_C_FADDRESS)
|
||||
MY_CHECK_CXX_COMPILER_FLAG("-faddress-sanitizer" HAVE_CXX_FFADDRESS)
|
||||
|
||||
IF(HAVE_C_FADDRESS AND HAVE_CXX_FFADDRESS)
|
||||
# We switch on basic optimization also for debug builds.
|
||||
SET(CMAKE_C_FLAGS_DEBUG
|
||||
"${CMAKE_C_FLAGS_DEBUG} -faddress-sanitizer -O1 -fPIC")
|
||||
SET(CMAKE_C_FLAGS_RELWITHDEBINFO
|
||||
"${CMAKE_C_FLAGS_RELWITHDEBINFO} -faddress-sanitizer -fPIC")
|
||||
SET(CMAKE_CXX_FLAGS_DEBUG
|
||||
"${CMAKE_CXX_FLAGS_DEBUG} -faddress-sanitizer -O1 -fPIC")
|
||||
SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO
|
||||
"${CMAKE_CXX_FLAGS_RELWITHDEBINFO} -faddress-sanitizer -fPIC")
|
||||
SET(WITH_ASAN_OK 1)
|
||||
ENDIF()
|
||||
ENDIF()
|
||||
|
||||
IF(NOT WITH_ASAN_OK)
|
||||
MESSAGE(FATAL_ERROR "Do not know how to enable address sanitizer")
|
||||
ENDIF()
|
||||
ENDIF()
|
||||
|
||||
|
||||
OPTION(ENABLE_DEBUG_SYNC "Enable debug sync (debug builds only)" ON)
|
||||
IF(ENABLE_DEBUG_SYNC)
|
||||
SET(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -DENABLED_DEBUG_SYNC")
|
||||
@ -261,6 +336,11 @@ ENDIF()
|
||||
# Run platform tests
|
||||
INCLUDE(configure.cmake)
|
||||
|
||||
# Find header files from the bundled libraries
|
||||
# (jemalloc, yassl, readline, pcre, etc)
|
||||
# before the ones installed in the system
|
||||
SET(CMAKE_INCLUDE_DIRECTORIES_PROJECT_BEFORE ON)
|
||||
|
||||
# Common defines and includes
|
||||
ADD_DEFINITIONS(-DHAVE_CONFIG_H)
|
||||
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/include)
|
||||
|
@ -1227,7 +1227,7 @@ int main(int argc,char *argv[])
|
||||
|
||||
put_info("Welcome to the MariaDB monitor. Commands end with ; or \\g.",
|
||||
INFO_INFO);
|
||||
sprintf((char*) glob_buffer.ptr(),
|
||||
my_snprintf((char*) glob_buffer.ptr(), glob_buffer.alloced_length(),
|
||||
"Your %s connection id is %lu\nServer version: %s\n",
|
||||
mysql_get_server_name(&mysql),
|
||||
mysql_thread_id(&mysql), server_version_string(&mysql));
|
||||
@ -1411,7 +1411,8 @@ sig_handler window_resize(int sig)
|
||||
struct winsize window_size;
|
||||
|
||||
if (ioctl(fileno(stdin), TIOCGWINSZ, &window_size) == 0)
|
||||
terminal_width= window_size.ws_col;
|
||||
if (window_size.ws_col > 0)
|
||||
terminal_width= window_size.ws_col;
|
||||
}
|
||||
#endif
|
||||
|
||||
@ -1675,8 +1676,9 @@ static void usage(int version)
|
||||
return;
|
||||
puts(ORACLE_WELCOME_COPYRIGHT_NOTICE("2000"));
|
||||
printf("Usage: %s [OPTIONS] [database]\n", my_progname);
|
||||
my_print_help(my_long_options);
|
||||
print_defaults("my", load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
}
|
||||
|
||||
|
@ -22,7 +22,7 @@
|
||||
|
||||
#include <welcome_copyright_notice.h> /* ORACLE_WELCOME_COPYRIGHT_NOTICE */
|
||||
|
||||
#define VER "1.3"
|
||||
#define VER "1.3a"
|
||||
|
||||
#ifdef HAVE_SYS_WAIT_H
|
||||
#include <sys/wait.h>
|
||||
@ -164,6 +164,15 @@ static struct my_option my_long_options[]=
|
||||
};
|
||||
|
||||
|
||||
static const char *load_default_groups[]=
|
||||
{
|
||||
"client", /* Read settings how to connect to server */
|
||||
"mysql_upgrade", /* Read special settings for mysql_upgrade */
|
||||
"client-server", /* Reads settings common between client & server */
|
||||
"client-mariadb", /* Read mariadb unique client settings */
|
||||
0
|
||||
};
|
||||
|
||||
static void free_used_memory(void)
|
||||
{
|
||||
/* Free memory allocated by 'load_defaults' */
|
||||
@ -180,6 +189,7 @@ static void die(const char *fmt, ...)
|
||||
DBUG_ENTER("die");
|
||||
|
||||
/* Print the error message */
|
||||
fflush(stdout);
|
||||
va_start(args, fmt);
|
||||
if (fmt)
|
||||
{
|
||||
@ -259,8 +269,11 @@ get_one_option(int optid, const struct my_option *opt,
|
||||
printf("%s Ver %s Distrib %s, for %s (%s)\n",
|
||||
my_progname, VER, MYSQL_SERVER_VERSION, SYSTEM_TYPE, MACHINE_TYPE);
|
||||
puts(ORACLE_WELCOME_COPYRIGHT_NOTICE("2000"));
|
||||
puts("MariaDB utility for upgrading databases to new MariaDB versions.\n");
|
||||
puts("MariaDB utility for upgrading databases to new MariaDB versions.");
|
||||
print_defaults("my", load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
die(0);
|
||||
break;
|
||||
|
||||
@ -736,6 +749,7 @@ static int run_mysqlcheck_upgrade(void)
|
||||
!opt_silent || opt_verbose ? "--verbose": "",
|
||||
opt_silent ? "--silent": "",
|
||||
opt_write_binlog ? "--write-binlog" : "--skip-write-binlog",
|
||||
"2>&1",
|
||||
NULL);
|
||||
}
|
||||
|
||||
@ -754,6 +768,7 @@ static int run_mysqlcheck_fixnames(void)
|
||||
opt_verbose ? "--verbose": "",
|
||||
opt_silent ? "--silent": "",
|
||||
opt_write_binlog ? "--write-binlog" : "--skip-write-binlog",
|
||||
"2>&1",
|
||||
NULL);
|
||||
}
|
||||
|
||||
@ -874,14 +889,11 @@ static int run_sql_fix_privilege_tables(void)
|
||||
}
|
||||
|
||||
|
||||
static const char *load_default_groups[]=
|
||||
static void print_error(const char *error_msg, DYNAMIC_STRING *output)
|
||||
{
|
||||
"client", /* Read settings how to connect to server */
|
||||
"mysql_upgrade", /* Read special settings for mysql_upgrade */
|
||||
"client-server", /* Reads settings common between client & server */
|
||||
"client-mariadb", /* Read mariadb unique client settings */
|
||||
0
|
||||
};
|
||||
fprintf(stderr, "%s\n", error_msg);
|
||||
fprintf(stderr, "%s", output->str);
|
||||
}
|
||||
|
||||
|
||||
/* Convert the specified version string into the numeric format. */
|
||||
@ -914,6 +926,8 @@ static int check_version_match(void)
|
||||
&ds_version, FALSE) ||
|
||||
extract_variable_from_show(&ds_version, version_str))
|
||||
{
|
||||
print_error("Version check failed. Got the following error when calling "
|
||||
"the 'mysql' command line client", &ds_version);
|
||||
dynstr_free(&ds_version);
|
||||
return 1; /* Query failed */
|
||||
}
|
||||
@ -982,7 +996,8 @@ int main(int argc, char **argv)
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("The --upgrade-system-tables option was used, databases won't be touched.\n");
|
||||
if (!opt_silent)
|
||||
printf("The --upgrade-system-tables option was used, databases won't be touched.\n");
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -1230,9 +1230,10 @@ static void usage(void)
|
||||
puts(ORACLE_WELCOME_COPYRIGHT_NOTICE("2000"));
|
||||
puts("Administration program for the mysqld daemon.");
|
||||
printf("Usage: %s [OPTIONS] command command....\n", my_progname);
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("\nWhere command is a one or more of: (Commands may be shortened)\n\
|
||||
create databasename Create a new database\n\
|
||||
debug Instruct server to write debug information to log\n\
|
||||
|
@ -1546,6 +1546,8 @@ static void usage()
|
||||
Dumps a MySQL binary log in a format usable for viewing or for piping to\n\
|
||||
the mysql command line client.\n\n");
|
||||
printf("Usage: %s [options] log-files\n", my_progname);
|
||||
print_defaults("my",load_groups);
|
||||
puts("");
|
||||
my_print_help(my_options);
|
||||
my_print_variables(my_options);
|
||||
}
|
||||
|
@ -250,6 +250,7 @@ static void usage(void)
|
||||
puts("http://kb.askmonty.org/v/mysqlcheck for latest information about");
|
||||
puts("this program.");
|
||||
print_defaults("my", load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
DBUG_VOID_RETURN;
|
||||
|
@ -612,7 +612,8 @@ static void usage(void)
|
||||
puts("Dumping structure and contents of MySQL databases and tables.");
|
||||
short_usage_sub();
|
||||
print_defaults("my",load_default_groups);
|
||||
my_print_help(my_long_options);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
} /* usage */
|
||||
|
||||
|
@ -216,8 +216,9 @@ If one uses sockets to connect to the MySQL server, the server will open and\n\
|
||||
read the text file directly. In other cases the client will open the text\n\
|
||||
file. The SQL command 'LOAD DATA INFILE' is used to import the rows.\n");
|
||||
|
||||
printf("\nUsage: %s [OPTIONS] database textfile...",my_progname);
|
||||
printf("\nUsage: %s [OPTIONS] database textfile...\n",my_progname);
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
}
|
||||
|
@ -286,6 +286,7 @@ If no table is given, then all matching tables in database are shown.\n\
|
||||
If no column is given, then all matching columns and column types in table\n\
|
||||
are shown.");
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
}
|
||||
|
@ -739,7 +739,9 @@ static void usage(void)
|
||||
puts("Run a query multiple times against the server.\n");
|
||||
printf("Usage: %s [OPTIONS]\n",my_progname);
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
my_print_variables(my_long_options);
|
||||
}
|
||||
|
||||
|
||||
|
@ -7030,8 +7030,9 @@ void usage()
|
||||
puts(ORACLE_WELCOME_COPYRIGHT_NOTICE("2000"));
|
||||
printf("Runs a test against the mysql server and compares output with a results file.\n\n");
|
||||
printf("Usage: %s [OPTIONS] [database] < test_file\n", my_progname);
|
||||
print_defaults("my",load_default_groups);
|
||||
puts("");
|
||||
my_print_help(my_long_options);
|
||||
printf(" --no-defaults Don't read default options from any options file.\n");
|
||||
my_print_variables(my_long_options);
|
||||
}
|
||||
|
||||
|
@ -25,10 +25,10 @@ FUNCTION (INSTALL_DEBUG_SYMBOLS)
|
||||
)
|
||||
|
||||
IF(NOT ARG_COMPONENT)
|
||||
MESSAGE(FATAL_ERROR "No COMPONENT passed to INSTALL_DEBUG_SYMBOLS")
|
||||
SET(ARG_COMPONENT DebugBinaries)
|
||||
ENDIF()
|
||||
IF(NOT ARG_INSTALL_LOCATION)
|
||||
MESSAGE(FATAL_ERROR "No INSTALL_LOCATION passed to INSTALL_DEBUG_SYMBOLS")
|
||||
SET(ARG_INSTALL_LOCATION lib)
|
||||
ENDIF()
|
||||
SET(targets ${ARG_DEFAULT_ARGS})
|
||||
FOREACH(target ${targets})
|
||||
|
@ -1,5 +1,5 @@
|
||||
|
||||
# Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
# Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
@ -34,7 +34,10 @@ ENDFOREACH()
|
||||
|
||||
# Ensure we have clean build for shared libraries
|
||||
# without unresolved symbols
|
||||
SET(LINK_FLAG_NO_UNDEFINED "-Wl,--no-undefined")
|
||||
# Not supported with AddressSanitizer
|
||||
IF(NOT WITH_ASAN)
|
||||
SET(LINK_FLAG_NO_UNDEFINED "-Wl,--no-undefined")
|
||||
ENDIF()
|
||||
|
||||
# 64 bit file offset support flag
|
||||
SET(_FILE_OFFSET_BITS 64)
|
||||
|
@ -140,6 +140,10 @@ IF(UNIX)
|
||||
|
||||
SET(CMAKE_REQUIRED_LIBRARIES
|
||||
${LIBM} ${LIBNSL} ${LIBBIND} ${LIBCRYPT} ${LIBSOCKET} ${LIBDL} ${CMAKE_THREAD_LIBS_INIT} ${LIBRT} ${LIBEXECINFO})
|
||||
# Need explicit pthread for gcc -fsanitize=address
|
||||
IF(CMAKE_USE_PTHREADS_INIT AND CMAKE_C_FLAGS MATCHES "-fsanitize=")
|
||||
SET(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} pthread)
|
||||
ENDIF()
|
||||
|
||||
IF(CMAKE_REQUIRED_LIBRARIES)
|
||||
LIST(REMOVE_DUPLICATES CMAKE_REQUIRED_LIBRARIES)
|
||||
|
17
debian/dist/Debian/control
vendored
17
debian/dist/Debian/control
vendored
@ -14,7 +14,7 @@ Package: libmariadbclient18
|
||||
Section: libs
|
||||
Architecture: any
|
||||
Depends: mariadb-common, libmysqlclient18 (= ${source:Version}), ${shlibs:Depends}, ${misc:Depends}
|
||||
Conflicts: mariadb-server-10.0 (<< 10.0.5), mariadb-galera-server-10.0 (<< 10.0.5),
|
||||
Breaks: mariadb-server-10.0 (<< 10.0.5), mariadb-galera-server-10.0 (<< 10.0.5),
|
||||
mariadb-server-5.5 (<< 5.5.33), mariadb-galera-server-5.5 (<< 5.5.33),
|
||||
mariadb-server-5.1, mariadb-server-5.2, mariadb-server-5.3
|
||||
Description: MariaDB database client library
|
||||
@ -45,7 +45,7 @@ Architecture: any
|
||||
Section: libdevel
|
||||
Depends: libmariadbclient-dev (>= ${source:Version}), ${misc:Depends}
|
||||
Provides: libmysqld-dev
|
||||
Conflicts: libmysqld-dev
|
||||
Breaks: libmysqld-dev
|
||||
Replaces: libmysqld-dev
|
||||
Description: MariaDB embedded database development files
|
||||
MariaDB is a fast, stable and true multi-user, multi-threaded SQL database
|
||||
@ -60,7 +60,7 @@ Architecture: any
|
||||
Section: libdevel
|
||||
Depends: libmariadbclient18 (>= ${source:Version}), zlib1g-dev, , ${shlibs:Depends}, ${misc:Depends}
|
||||
Replaces: libmariadbclient16-dev, libmysqlclient16-dev
|
||||
Conflicts: libmysqlclient-dev, libmariadbclient16-dev, libmysqlclient14-dev, libmysqlclient12-dev, libmysqlclient10-dev, libmysqlclient15-dev, libmysqlclient16-dev
|
||||
Breaks: libmysqlclient-dev, libmariadbclient16-dev, libmysqlclient14-dev, libmysqlclient12-dev, libmysqlclient10-dev, libmysqlclient15-dev, libmysqlclient16-dev
|
||||
Provides: libmysqlclient-dev
|
||||
Description: MariaDB database development files
|
||||
MariaDB is a fast, stable and true multi-user, multi-threaded SQL database
|
||||
@ -100,7 +100,7 @@ Package: mariadb-client-core-10.0
|
||||
Architecture: any
|
||||
Depends: mariadb-common, libmariadbclient18 (>= ${source:Version}), ${shlibs:Depends}, ${misc:Depends}
|
||||
Provides: mysql-client-core, mysql-client-core-5.1, mysql-client-core-5.5
|
||||
Conflicts: mysql-client (<< 5.0.51), mysql-client-5.0,
|
||||
Breaks: mysql-client (<< 5.0.51), mysql-client-5.0,
|
||||
mysql-client-5.1 (<< ${source:Version}), mysql-client-5.5 (<< ${source:Version}),
|
||||
mysql-client-core-5.1, mysql-client-core-5.5,
|
||||
mariadb-client-5.1, mariadb-client-core-5.1,
|
||||
@ -125,7 +125,7 @@ Architecture: any
|
||||
Depends: debianutils (>=1.6), libdbi-perl, libdbd-mysql-perl (>= 1.2202), mariadb-common, libmariadbclient18 (>= ${source:Version}), mariadb-client-core-10.0 (>= ${source:Version}), ${perl:Depends}, ${shlibs:Depends}, ${misc:Depends}
|
||||
Provides: virtual-mysql-client, mysql-client,
|
||||
mysql-client-4.1, mysql-client-5.1, mysql-client-5.5
|
||||
Conflicts: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
Breaks: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
mariadb-client (<< ${source:Version}),
|
||||
mariadb-client-5.1, mariadb-client-5.2, mariadb-client-5.3, mysql-client-5.5
|
||||
Replaces: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
@ -145,7 +145,7 @@ Package: mariadb-server-core-10.0
|
||||
Architecture: any
|
||||
Depends: ${shlibs:Depends}, ${misc:Depends}, libmariadbclient18 (>= ${binary:Version})
|
||||
Provides: mysql-server-core, mysql-server-core-5.1, mysql-server-core-5.5
|
||||
Conflicts: mariadb-server-5.1 (<< 5.1.60),
|
||||
Breaks: mariadb-server-5.1 (<< 5.1.60),
|
||||
mariadb-server-5.2 (<< 5.2.10),
|
||||
mariadb-server-5.3 (<< 5.3.3),
|
||||
mysql-server-5.0,
|
||||
@ -169,9 +169,10 @@ Package: mariadb-test-10.0
|
||||
Section: database
|
||||
Architecture: any
|
||||
Depends: mariadb-server-10.0 (= ${source:Version}), mariadb-client-10.0 (= ${source:Version})
|
||||
Conflicts: mariadb-test (<< ${source:Version}),
|
||||
Breaks: mariadb-test (<< ${source:Version}),
|
||||
mariadb-test-5.1, mariadb-test-5.2, mariadb-test-5.3,
|
||||
mariadb-server-5.5 (<< 5.5.33), mariadb-galera-server-5.5 (<< 5.5.33)
|
||||
Suggests: patch
|
||||
Replaces: mariadb-test (<< ${source:Version}),
|
||||
mariadb-test-5.1, mariadb-test-5.2, mariadb-test-5.3
|
||||
Description: MariaDB database regression test suite
|
||||
@ -189,7 +190,7 @@ Recommends: libhtml-template-perl
|
||||
Pre-Depends: mariadb-common, adduser (>= 3.40), debconf
|
||||
Depends: mariadb-client-10.0 (>= ${source:Version}), libdbi-perl, perl (>= 5.6), ${shlibs:Depends}, ${misc:Depends}, psmisc, passwd, lsb-base (>= 3.0-10), mariadb-server-core-10.0 (>= ${binary:Version})
|
||||
Provides: mariadb-server, mysql-server, virtual-mysql-server
|
||||
Conflicts: mariadb-server (<< ${source:Version}), mysql-server (<< ${source:Version}),
|
||||
Breaks: mariadb-server (<< ${source:Version}), mysql-server (<< ${source:Version}),
|
||||
mysql-server-4.1, mysql-server-5.0, mysql-server-5.1, mysql-server-5.5,
|
||||
mariadb-server-5.1, mariadb-server-5.2, mariadb-server-5.3,
|
||||
mariadb-tokudb-engine-5.5, mariadb-tokudb-engine-10.0
|
||||
|
@ -10,7 +10,6 @@ usr/lib/mysql/plugin/query_cache_info.so
|
||||
usr/lib/mysql/plugin/query_response_time.so
|
||||
usr/lib/mysql/plugin/semisync_master.so
|
||||
usr/lib/mysql/plugin/semisync_slave.so
|
||||
usr/lib/mysql/plugin/sphinx.so
|
||||
usr/lib/mysql/plugin/sql_errlog.so
|
||||
usr/lib/libhsclient.so.*
|
||||
etc/mysql/debian-start
|
||||
|
5
debian/dist/Debian/rules
vendored
5
debian/dist/Debian/rules
vendored
@ -87,11 +87,6 @@ build-stamp: configure
|
||||
cd $(builddir) && $(MAKE) $(MAKE_J) $(AM_EXTRA_MAKEFLAGS)
|
||||
|
||||
ifeq ($(findstring nocheck,$(DEB_BUILD_OPTIONS)),)
|
||||
# Don't know why the following is necessary...
|
||||
cp unittest/unit.pl $(builddir)/unittest/
|
||||
cp -r mysql-test/* $(builddir)/mysql-test/
|
||||
cp -r sql/share/* $(builddir)/sql/share/
|
||||
cp -r scripts/*sql $(builddir)/scripts/
|
||||
if [ ! -f testsuite-stamp ] ; then \
|
||||
cd $(builddir) && $(MAKE) $(MAKE_TEST_TARGET) || $(TESTSUITE_FAIL_CMD) ; \
|
||||
fi
|
||||
|
17
debian/dist/Ubuntu/control
vendored
17
debian/dist/Ubuntu/control
vendored
@ -14,7 +14,7 @@ Package: libmariadbclient18
|
||||
Section: libs
|
||||
Architecture: any
|
||||
Depends: mariadb-common, libmysqlclient18 (= ${source:Version}), ${shlibs:Depends}, ${misc:Depends}
|
||||
Conflicts: mariadb-server-10.0 (<< 10.0.5), mariadb-galera-server-10.0 (<< 10.0.5),
|
||||
Breaks: mariadb-server-10.0 (<< 10.0.5), mariadb-galera-server-10.0 (<< 10.0.5),
|
||||
mariadb-server-5.5 (<< 5.5.33), mariadb-galera-server-5.5 (<< 5.5.33),
|
||||
mariadb-server-5.1, mariadb-server-5.2, mariadb-server-5.3
|
||||
Description: MariaDB database client library
|
||||
@ -45,7 +45,7 @@ Architecture: any
|
||||
Section: libdevel
|
||||
Depends: libmariadbclient-dev (>= ${source:Version}), ${misc:Depends}
|
||||
Provides: libmysqld-dev
|
||||
Conflicts: libmysqld-dev
|
||||
Breaks: libmysqld-dev
|
||||
Replaces: libmysqld-dev
|
||||
Description: MariaDB embedded database development files
|
||||
MariaDB is a fast, stable and true multi-user, multi-threaded SQL database
|
||||
@ -60,7 +60,7 @@ Architecture: any
|
||||
Section: libdevel
|
||||
Depends: libmariadbclient18 (>= ${source:Version}), zlib1g-dev, , ${shlibs:Depends}, ${misc:Depends}
|
||||
Replaces: libmariadbclient16-dev, libmysqlclient16-dev
|
||||
Conflicts: libmysqlclient-dev, libmariadbclient16-dev, libmysqlclient14-dev, libmysqlclient12-dev, libmysqlclient10-dev, libmysqlclient15-dev, libmysqlclient16-dev
|
||||
Breaks: libmysqlclient-dev, libmariadbclient16-dev, libmysqlclient14-dev, libmysqlclient12-dev, libmysqlclient10-dev, libmysqlclient15-dev, libmysqlclient16-dev
|
||||
Provides: libmysqlclient-dev
|
||||
Description: MariaDB database development files
|
||||
MariaDB is a fast, stable and true multi-user, multi-threaded SQL database
|
||||
@ -100,7 +100,7 @@ Package: mariadb-client-core-10.0
|
||||
Architecture: any
|
||||
Depends: mariadb-common, libmariadbclient18 (>= ${source:Version}), ${shlibs:Depends}, ${misc:Depends}
|
||||
Provides: mysql-client-core, mysql-client-core-5.1, mysql-client-core-5.5
|
||||
Conflicts: mysql-client (<< 5.0.51), mysql-client-5.0,
|
||||
Breaks: mysql-client (<< 5.0.51), mysql-client-5.0,
|
||||
mysql-client-5.1 (<< ${source:Version}), mysql-client-5.5 (<< ${source:Version}),
|
||||
mysql-client-core-5.1, mysql-client-core-5.5,
|
||||
mariadb-client-5.1, mariadb-client-core-5.1,
|
||||
@ -125,7 +125,7 @@ Architecture: any
|
||||
Depends: debianutils (>=1.6), libdbi-perl, libdbd-mysql-perl (>= 1.2202), mariadb-common, libmariadbclient18 (>= ${source:Version}), mariadb-client-core-10.0 (>= ${source:Version}), ${perl:Depends}, ${shlibs:Depends}, ${misc:Depends}
|
||||
Provides: virtual-mysql-client, mysql-client,
|
||||
mysql-client-4.1, mysql-client-5.1, mysql-client-5.5
|
||||
Conflicts: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
Breaks: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
mariadb-client (<< ${source:Version}),
|
||||
mariadb-client-5.1, mariadb-client-5.2, mariadb-client-5.3, mysql-client-5.5
|
||||
Replaces: mysql-client (<< 5.0.51), mysql-client-5.0, mysql-client-5.1,
|
||||
@ -145,7 +145,7 @@ Package: mariadb-server-core-10.0
|
||||
Architecture: any
|
||||
Depends: ${shlibs:Depends}, ${misc:Depends}, libmariadbclient18 (>= ${binary:Version})
|
||||
Provides: mysql-server-core, mysql-server-core-5.1, mysql-server-core-5.5
|
||||
Conflicts: mysql-server-5.0,
|
||||
Breaks: mysql-server-5.0,
|
||||
mysql-server-core-5.0, mysql-server-core-5.1, mysql-server-core-5.5,
|
||||
mariadb-server-core-5.1, mariadb-server-core-5.2, mariadb-server-core-5.5
|
||||
Replaces: mysql-server-5.0,
|
||||
@ -163,7 +163,8 @@ Package: mariadb-test-10.0
|
||||
Section: database
|
||||
Architecture: any
|
||||
Depends: mariadb-server-10.0 (= ${source:Version}), mariadb-client-10.0 (= ${source:Version})
|
||||
Conflicts: mariadb-test (<< ${source:Version}),
|
||||
Suggests: patch
|
||||
Breaks: mariadb-test (<< ${source:Version}),
|
||||
mariadb-test-5.1, mariadb-test-5.2, mariadb-test-5.3,
|
||||
mariadb-server-5.5 (<< 5.5.33), mariadb-galera-server-5.5 (<< 5.5.33)
|
||||
Replaces: mariadb-test (<< ${source:Version}),
|
||||
@ -183,7 +184,7 @@ Recommends: libhtml-template-perl
|
||||
Pre-Depends: mariadb-common, adduser (>= 3.40), debconf
|
||||
Depends: mariadb-client-10.0 (>= ${source:Version}), libdbi-perl, perl (>= 5.6), ${shlibs:Depends}, ${misc:Depends}, psmisc, passwd, lsb-base (>= 3.0-10), mariadb-server-core-10.0 (>= ${binary:Version})
|
||||
Provides: mariadb-server, mysql-server, virtual-mysql-server
|
||||
Conflicts: mariadb-server (<< ${source:Version}), mysql-server (<< ${source:Version}),
|
||||
Breaks: mariadb-server (<< ${source:Version}), mysql-server (<< ${source:Version}),
|
||||
mysql-server-4.1, mysql-server-5.0, mysql-server-5.1, mysql-server-5.5,
|
||||
mariadb-server-5.1, mariadb-server-5.2, mariadb-server-5.3,
|
||||
mariadb-tokudb-engine-5.5, mariadb-tokudb-engine-10.0
|
||||
|
@ -1,6 +1,7 @@
|
||||
usr/lib/mysql/plugin/auth_pam.so
|
||||
usr/lib/mysql/plugin/auth_socket.so
|
||||
usr/lib/mysql/plugin/ha_sequence.so
|
||||
usr/lib/mysql/plugin/ha_sphinx.so
|
||||
usr/lib/mysql/plugin/ha_xtradb.so
|
||||
usr/lib/mysql/plugin/handlersocket.so
|
||||
usr/lib/mysql/plugin/locales.so
|
||||
@ -9,7 +10,6 @@ usr/lib/mysql/plugin/query_cache_info.so
|
||||
usr/lib/mysql/plugin/query_response_time.so
|
||||
usr/lib/mysql/plugin/semisync_master.so
|
||||
usr/lib/mysql/plugin/semisync_slave.so
|
||||
usr/lib/mysql/plugin/sphinx.so
|
||||
usr/lib/mysql/plugin/sql_errlog.so
|
||||
usr/lib/libhsclient.so.*
|
||||
etc/apparmor.d/usr.sbin.mysqld
|
||||
|
5
debian/dist/Ubuntu/rules
vendored
5
debian/dist/Ubuntu/rules
vendored
@ -87,11 +87,6 @@ build-stamp: configure
|
||||
cd $(builddir) && $(MAKE) $(MAKE_J) $(AM_EXTRA_MAKEFLAGS)
|
||||
|
||||
ifeq ($(findstring nocheck,$(DEB_BUILD_OPTIONS)),)
|
||||
# Don't know why the following is necessary...
|
||||
cp unittest/unit.pl $(builddir)/unittest/
|
||||
cp -r mysql-test/* $(builddir)/mysql-test/
|
||||
cp -r sql/share/* $(builddir)/sql/share/
|
||||
cp -r scripts/*sql $(builddir)/scripts/
|
||||
if [ ! -f testsuite-stamp ] ; then \
|
||||
cd $(builddir) && $(MAKE) $(MAKE_TEST_TARGET) || $(TESTSUITE_FAIL_CMD) ; \
|
||||
fi
|
||||
|
@ -10,21 +10,30 @@
|
||||
@DPATCH@
|
||||
--- old/scripts/mysql_system_tables_data.sql 2008-12-04 22:59:44.000000000 +0100
|
||||
+++ new/scripts/mysql_system_tables_data.sql 2008-12-04 23:00:07.000000000 +0100
|
||||
@@ -31,8 +31,6 @@
|
||||
-- Fill "db" table with default grants for anyone to
|
||||
-- access database 'test' and 'test_%' if "db" table didn't exist
|
||||
CREATE TEMPORARY TABLE tmp_db LIKE db;
|
||||
@@ -26,16 +26,6 @@
|
||||
-- a plain character
|
||||
SELECT LOWER( REPLACE((SELECT REPLACE(@@hostname,'_','\_')),'%','\%') )INTO @current_hostname;
|
||||
|
||||
-
|
||||
--- Fill "db" table with default grants for anyone to
|
||||
--- access database 'test' and 'test_%' if "db" table didn't exist
|
||||
-CREATE TEMPORARY TABLE tmp_db LIKE db;
|
||||
-INSERT INTO tmp_db VALUES ('%','test','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y','Y','Y','Y','N','N','Y','Y');
|
||||
-INSERT INTO tmp_db VALUES ('%','test\_%','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y','Y','Y','Y','N','N','Y','Y');
|
||||
INSERT INTO db SELECT * FROM tmp_db WHERE @had_db_table=0;
|
||||
DROP TABLE tmp_db;
|
||||
|
||||
@@ -44,8 +42,6 @@
|
||||
REPLACE INTO tmp_user SELECT @current_hostname,'root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0,'','','N','N' FROM dual WHERE LOWER( @current_hostname) != 'localhost';
|
||||
-INSERT INTO db SELECT * FROM tmp_db WHERE @had_db_table=0;
|
||||
-DROP TABLE tmp_db;
|
||||
-
|
||||
-
|
||||
-- Fill "user" table with default users allowing root access
|
||||
-- from local machine if "user" table didn't exist before
|
||||
CREATE TEMPORARY TABLE tmp_user LIKE user;
|
||||
@@ -43,8 +33,6 @@ INSERT INTO tmp_user VALUES ('localhost'
|
||||
REPLACE INTO tmp_user SELECT @current_hostname,'root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0,'','','N','N' FROM dual WHERE @current_hostname != 'localhost';
|
||||
REPLACE INTO tmp_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','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0,'','','N','N');
|
||||
REPLACE INTO tmp_user VALUES ('::1','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0,'','','N','N');
|
||||
-INSERT INTO tmp_user (host,user) VALUES ('localhost','');
|
||||
-INSERT INTO tmp_user (host,user) SELECT @current_hostname,'' FROM dual WHERE LOWER(@current_hostname ) != 'localhost';
|
||||
-INSERT INTO tmp_user (host,user) SELECT @current_hostname,'' FROM dual WHERE @current_hostname != 'localhost';
|
||||
INSERT INTO user SELECT * FROM tmp_user WHERE @had_user_table=0;
|
||||
DROP TABLE tmp_user;
|
||||
|
||||
|
||||
|
@ -9,7 +9,7 @@
|
||||
|
||||
--- a/scripts/mysqld_safe.sh 2013-01-11 16:02:41 +0000
|
||||
+++ b/scripts/mysqld_safe.sh 2013-01-11 16:03:14 +0000
|
||||
@@ -30,7 +30,6 @@
|
||||
@@ -32,7 +32,6 @@ err_log=
|
||||
syslog_tag_mysqld=mysqld
|
||||
syslog_tag_mysqld_safe=mysqld_safe
|
||||
|
||||
@ -17,7 +17,7 @@
|
||||
|
||||
# MySQL-specific environment variable. First off, it's not really a umask,
|
||||
# it's the desired mode. Second, it follows umask(2), not umask(3) in that
|
||||
@@ -156,7 +155,7 @@
|
||||
@@ -163,7 +162,7 @@ eval_log_error () {
|
||||
# sed buffers output (only GNU sed supports a -u (unbuffered) option)
|
||||
# which means that messages may not get sent to syslog until the
|
||||
# mysqld process quits.
|
||||
@ -26,7 +26,7 @@
|
||||
;;
|
||||
*)
|
||||
echo "Internal program error (non-fatal):" \
|
||||
@@ -758,6 +757,13 @@
|
||||
@@ -805,6 +804,13 @@ then
|
||||
fi
|
||||
|
||||
#
|
||||
|
@ -9,12 +9,12 @@
|
||||
|
||||
--- mysql-dfsg-5.1-5.1.23rc.orig/scripts/mysql_install_db.sh 2008-01-29 22:41:20.000000000 +0100
|
||||
+++ mysql-dfsg-5.1-5.1.23rc/scripts/mysql_install_db.sh 2008-02-28 10:08:11.000000000 +0100
|
||||
@@ -306,7 +306,7 @@
|
||||
@@ -372,7 +372,7 @@ then
|
||||
fi
|
||||
|
||||
# Create database directories
|
||||
-for dir in "$ldata" "$ldata/mysql" "$ldata/test"
|
||||
+for dir in "$ldata" "$ldata/mysql"
|
||||
do
|
||||
if test ! -d $dir
|
||||
if test ! -d "$dir"
|
||||
then
|
||||
|
@ -8,7 +8,7 @@
|
||||
diff -Nur mysql-dfsg-5.1-5.1.31.orig/scripts/mysql_config.sh mysql-dfsg-5.1-5.1.31/scripts/mysql_config.sh
|
||||
--- mysql-dfsg-5.1-5.1.31.orig/scripts/mysql_config.sh 2009-01-19 17:30:55.000000000 +0100
|
||||
+++ mysql-dfsg-5.1-5.1.31/scripts/mysql_config.sh 2009-02-08 17:17:48.000000000 +0100
|
||||
@@ -110,10 +110,10 @@
|
||||
@@ -106,10 +106,10 @@ fi
|
||||
|
||||
# Create options
|
||||
# We intentionally add a space to the beginning and end of lib strings, simplifies replace later
|
||||
|
4
debian/patches/50_mysql-test__db_test.dpatch
vendored
4
debian/patches/50_mysql-test__db_test.dpatch
vendored
@ -10,9 +10,9 @@
|
||||
|
||||
--- old/mysql-test/mysql-test-run.pl 2009-06-16 14:24:09.000000000 +0200
|
||||
+++ new/mysql-test/mysql-test-run.pl 2009-07-04 00:03:34.000000000 +0200
|
||||
@@ -2717,6 +2717,11 @@
|
||||
@@ -3578,6 +3578,11 @@ sub mysql_install_db {
|
||||
mtr_appendfile_to_file("$sql_dir/mysql_system_tables_data.sql",
|
||||
$bootstrap_sql_file);
|
||||
$bootstrap_sql_file);
|
||||
|
||||
+ mtr_tofile($bootstrap_sql_file, "-- Debian removed the default privileges on the 'test' database\n");
|
||||
+ mtr_tofile($bootstrap_sql_file, "INSERT INTO mysql.db VALUES ('%','test','','Y','Y','Y','Y','Y','Y','N','Y','Y','Y','Y','Y','Y','Y','Y','N','N','Y','Y');\n");
|
||||
|
@ -33,4 +33,9 @@ SET(YASSL_SOURCES src/buffer.cpp src/cert_wrapper.cpp src/crypto_wrapper.cpp sr
|
||||
ADD_CONVENIENCE_LIBRARY(yassl ${YASSL_SOURCES})
|
||||
RESTRICT_SYMBOL_EXPORTS(yassl)
|
||||
|
||||
INSTALL_DEBUG_SYMBOLS(yassl)
|
||||
IF(MSVC)
|
||||
INSTALL_DEBUG_TARGET(yassl DESTINATION ${INSTALL_LIBDIR}/debug)
|
||||
ENDIF()
|
||||
|
||||
|
||||
|
@ -32,3 +32,8 @@ SET(TAOCRYPT_SOURCES src/aes.cpp src/aestables.cpp src/algebra.cpp src/arc4.cpp
|
||||
ADD_CONVENIENCE_LIBRARY(taocrypt ${TAOCRYPT_SOURCES})
|
||||
RESTRICT_SYMBOL_EXPORTS(taocrypt)
|
||||
|
||||
INSTALL_DEBUG_SYMBOLS(taocrypt)
|
||||
IF(MSVC)
|
||||
INSTALL_DEBUG_TARGET(taocrypt DESTINATION ${INSTALL_LIBDIR}/debug)
|
||||
ENDIF()
|
||||
|
||||
|
@ -78,3 +78,4 @@
|
||||
{ "HA_ERR_ROW_NOT_VISIBLE", HA_ERR_ROW_NOT_VISIBLE, "" },
|
||||
{ "HA_ERR_ABORTED_BY_USER", HA_ERR_ABORTED_BY_USER, "" },
|
||||
{ "HA_ERR_DISK_FULL", HA_ERR_DISK_FULL, "" },
|
||||
{ "HA_ERR_INCOMPATIBLE_DEFINITION", HA_ERR_INCOMPATIBLE_DEFINITION, "" },
|
||||
|
@ -200,11 +200,6 @@ enum ha_extra_function {
|
||||
HA_EXTRA_ATTACH_CHILDREN,
|
||||
HA_EXTRA_IS_ATTACHED_CHILDREN,
|
||||
HA_EXTRA_DETACH_CHILDREN,
|
||||
/*
|
||||
Prepare table for export
|
||||
(e.g. quiesce the table and write table metadata).
|
||||
*/
|
||||
HA_EXTRA_EXPORT,
|
||||
HA_EXTRA_DETACH_CHILD,
|
||||
/* Inform handler we will force a close as part of flush */
|
||||
HA_EXTRA_PREPARE_FOR_FORCED_CLOSE
|
||||
@ -264,13 +259,11 @@ enum ha_base_keytype {
|
||||
#define HA_SPATIAL 1024 /* For spatial search */
|
||||
#define HA_NULL_ARE_EQUAL 2048 /* NULL in key are cmp as equal */
|
||||
#define HA_GENERATED_KEY 8192 /* Automaticly generated key */
|
||||
#define HA_RTREE_INDEX 16384 /* For RTREE search */
|
||||
|
||||
/* The combination of the above can be used for key type comparison. */
|
||||
#define HA_KEYFLAG_MASK (HA_NOSAME | HA_PACK_KEY | HA_AUTO_KEY | \
|
||||
HA_BINARY_PACK_KEY | HA_FULLTEXT | HA_UNIQUE_CHECK | \
|
||||
HA_SPATIAL | HA_NULL_ARE_EQUAL | HA_GENERATED_KEY | \
|
||||
HA_RTREE_INDEX)
|
||||
HA_SPATIAL | HA_NULL_ARE_EQUAL | HA_GENERATED_KEY)
|
||||
|
||||
/*
|
||||
Key contains partial segments.
|
||||
@ -507,7 +500,8 @@ enum ha_base_keytype {
|
||||
#define HA_ERR_ROW_NOT_VISIBLE 187
|
||||
#define HA_ERR_ABORTED_BY_USER 188
|
||||
#define HA_ERR_DISK_FULL 189
|
||||
#define HA_ERR_LAST 189 /* Copy of last error nr */
|
||||
#define HA_ERR_INCOMPATIBLE_DEFINITION 190
|
||||
#define HA_ERR_LAST 190 /* Copy of last error nr */
|
||||
|
||||
/* Number of different errors */
|
||||
#define HA_ERR_ERRORS (HA_ERR_LAST - HA_ERR_FIRST + 1)
|
||||
|
76
include/my_check_opt.h
Normal file
76
include/my_check_opt.h
Normal file
@ -0,0 +1,76 @@
|
||||
/* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; version 2 of the License.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */
|
||||
|
||||
#ifndef _my_check_opt_h
|
||||
#define _my_check_opt_h
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/*
|
||||
All given definitions needed for MyISAM storage engine:
|
||||
myisamchk.c or/and ha_myisam.cc or/and micheck.c
|
||||
Some definitions are needed by the MySQL parser.
|
||||
*/
|
||||
|
||||
#define T_AUTO_INC (1UL << 0)
|
||||
#define T_AUTO_REPAIR (1UL << 1)
|
||||
#define T_BACKUP_DATA (1UL << 2)
|
||||
#define T_CALC_CHECKSUM (1UL << 3)
|
||||
#define T_CHECK (1UL << 4)
|
||||
#define T_CHECK_ONLY_CHANGED (1UL << 5)
|
||||
#define T_CREATE_MISSING_KEYS (1UL << 6)
|
||||
#define T_DESCRIPT (1UL << 7)
|
||||
#define T_DONT_CHECK_CHECKSUM (1UL << 8)
|
||||
#define T_EXTEND (1UL << 9)
|
||||
#define T_FAST (1UL << 10)
|
||||
#define T_FORCE_CREATE (1UL << 11)
|
||||
#define T_FORCE_UNIQUENESS (1UL << 12)
|
||||
#define T_INFO (1UL << 13)
|
||||
/** CHECK TABLE...MEDIUM (the default) */
|
||||
#define T_MEDIUM (1UL << 14)
|
||||
/** CHECK TABLE...QUICK */
|
||||
#define T_QUICK (1UL << 15)
|
||||
#define T_READONLY (1UL << 16)
|
||||
#define T_REP (1UL << 17)
|
||||
#define T_REP_BY_SORT (1UL << 18)
|
||||
#define T_REP_PARALLEL (1UL << 19)
|
||||
#define T_RETRY_WITHOUT_QUICK (1UL << 20)
|
||||
#define T_SAFE_REPAIR (1UL << 21)
|
||||
#define T_SILENT (1UL << 22)
|
||||
#define T_SORT_INDEX (1UL << 23)
|
||||
#define T_SORT_RECORDS (1UL << 24)
|
||||
#define T_STATISTICS (1UL << 25)
|
||||
#define T_UNPACK (1UL << 26)
|
||||
#define T_UPDATE_STATE (1UL << 27)
|
||||
#define T_VERBOSE (1UL << 28)
|
||||
#define T_VERY_SILENT (1UL << 29)
|
||||
#define T_WAIT_FOREVER (1UL << 30)
|
||||
#define T_WRITE_LOOP (1UL << 31)
|
||||
#define T_ZEROFILL (1ULL << 32)
|
||||
#define T_ZEROFILL_KEEP_LSN (1ULL << 33)
|
||||
/** If repair should not bump create_rename_lsn */
|
||||
#define T_NO_CREATE_RENAME_LSN (1ULL << 34)
|
||||
#define T_CREATE_UNIQUE_BY_SORT (1ULL << 35)
|
||||
#define T_SUPPRESS_ERR_HANDLING (1ULL << 36)
|
||||
#define T_FORCE_SORT_MEMORY (1ULL << 37)
|
||||
|
||||
#define T_REP_ANY (T_REP | T_REP_BY_SORT | T_REP_PARALLEL)
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
#endif
|
@ -344,9 +344,6 @@ C_MODE_END
|
||||
#ifdef HAVE_FCNTL_H
|
||||
#include <fcntl.h>
|
||||
#endif
|
||||
#ifdef HAVE_SYS_TIMEB_H
|
||||
#include <sys/timeb.h> /* Avoid warnings on SCO */
|
||||
#endif
|
||||
#ifdef HAVE_SYS_STAT_H
|
||||
#include <sys/stat.h>
|
||||
#endif
|
||||
|
@ -92,7 +92,8 @@ static const char *handler_error_messages[]=
|
||||
"Row in wrong partition",
|
||||
"Row is not visible by the current transaction",
|
||||
"Operation was interrupted by end user (probably kill command?)",
|
||||
"Disk full"
|
||||
"Disk full",
|
||||
"Incompatible key or row definition between the MariaDB .frm file and the information in the storage engine. You have to dump and restore the table to fix this"
|
||||
};
|
||||
|
||||
#endif /* MYSYS_MY_HANDLER_ERRORS_INCLUDED */
|
||||
|
@ -29,7 +29,7 @@ extern "C" {
|
||||
#include "my_compare.h"
|
||||
#include <myisamchk.h>
|
||||
#include <mysql/plugin.h>
|
||||
|
||||
#include <my_check_opt.h>
|
||||
/*
|
||||
Limit max keys according to HA_MAX_POSSIBLE_KEY; See myisamchk.h for details
|
||||
*/
|
||||
@ -312,7 +312,6 @@ typedef struct st_mi_bit_buff
|
||||
uint error;
|
||||
} MI_BIT_BUFF;
|
||||
|
||||
|
||||
typedef struct st_sort_info
|
||||
{
|
||||
/* sync things */
|
||||
|
@ -27,48 +27,6 @@
|
||||
#ifndef _myisamchk_h
|
||||
#define _myisamchk_h
|
||||
|
||||
#define T_AUTO_INC 1
|
||||
#define T_AUTO_REPAIR 2 /* QQ to be removed */
|
||||
#define T_BACKUP_DATA 4
|
||||
#define T_CALC_CHECKSUM 8
|
||||
#define T_CHECK 16
|
||||
#define T_CHECK_ONLY_CHANGED 32
|
||||
#define T_CREATE_MISSING_KEYS 64
|
||||
#define T_DESCRIPT 128
|
||||
#define T_DONT_CHECK_CHECKSUM 256
|
||||
#define T_EXTEND 512
|
||||
#define T_FAST (1L << 10)
|
||||
#define T_FORCE_CREATE (1L << 11)
|
||||
#define T_FORCE_UNIQUENESS (1L << 12)
|
||||
#define T_INFO (1L << 13)
|
||||
#define T_MEDIUM (1L << 14)
|
||||
#define T_QUICK (1L << 15)
|
||||
#define T_READONLY (1L << 16)
|
||||
#define T_REP (1L << 17)
|
||||
#define T_REP_BY_SORT (1L << 18)
|
||||
#define T_REP_PARALLEL (1L << 19)
|
||||
#define T_RETRY_WITHOUT_QUICK (1L << 20)
|
||||
#define T_SAFE_REPAIR (1L << 21)
|
||||
#define T_SILENT (1L << 22)
|
||||
#define T_SORT_INDEX (1L << 23)
|
||||
#define T_SORT_RECORDS (1L << 24)
|
||||
#define T_STATISTICS (1L << 25)
|
||||
#define T_UNPACK (1L << 26)
|
||||
#define T_UPDATE_STATE (1L << 27)
|
||||
#define T_VERBOSE (1L << 28)
|
||||
#define T_VERY_SILENT (1L << 29)
|
||||
#define T_WAIT_FOREVER (1L << 30)
|
||||
#define T_WRITE_LOOP ((ulong) 1L << 31)
|
||||
#define T_ZEROFILL ((ulonglong) 1L << 32)
|
||||
#define T_ZEROFILL_KEEP_LSN ((ulonglong) 1L << 33)
|
||||
/** If repair should not bump create_rename_lsn */
|
||||
#define T_NO_CREATE_RENAME_LSN ((ulonglong) 1L << 34)
|
||||
#define T_CREATE_UNIQUE_BY_SORT ((ulonglong) 1L << 35)
|
||||
#define T_SUPPRESS_ERR_HANDLING ((ulonglong) 1L << 36)
|
||||
#define T_FORCE_SORT_MEMORY ((ulonglong) 1L << 37)
|
||||
|
||||
#define T_REP_ANY (T_REP | T_REP_BY_SORT | T_REP_PARALLEL)
|
||||
|
||||
/*
|
||||
Flags used by xxxxchk.c or/and ha_xxxx.cc that are NOT passed
|
||||
to xxxcheck.c follows:
|
||||
|
@ -353,8 +353,10 @@ SET(LIBS clientlib dbug strings vio mysys mysys_ssl ${ZLIB_LIBRARY} ${SSL_LIBRAR
|
||||
MERGE_LIBRARIES(mysqlclient STATIC ${LIBS} COMPONENT Development)
|
||||
|
||||
# Visual Studio users need debug static library for debug projects
|
||||
INSTALL_DEBUG_SYMBOLS(clientlib)
|
||||
IF(MSVC)
|
||||
INSTALL_DEBUG_TARGET(mysqlclient DESTINATION ${INSTALL_LIBDIR}/debug)
|
||||
INSTALL_DEBUG_TARGET(clientlib DESTINATION ${INSTALL_LIBDIR}/debug)
|
||||
ENDIF()
|
||||
|
||||
IF(UNIX)
|
||||
|
@ -15,7 +15,6 @@
|
||||
|
||||
#include <service_versions.h>
|
||||
|
||||
|
||||
/* file reserved for the future use */
|
||||
SERVICE_VERSION *logger_service= (void *) VERSION_logger;
|
||||
SERVICE_VERSION logger_service= (void *) VERSION_logger;
|
||||
|
||||
|
@ -74,7 +74,7 @@ ENDIF()
|
||||
|
||||
IF(WITH_EMBEDDED_SERVER)
|
||||
SET(TEST_EMBEDDED ${MTR_FORCE} --comment=embedded --timer --embedded-server
|
||||
--skip-rpl --skip-ndbcluster $(EXP))
|
||||
--skip-rpl --skip-ndbcluster ${EXP})
|
||||
ELSE()
|
||||
SET(TEST_EMBEDDED echo "Can not test embedded, not compiled in")
|
||||
ENDIF()
|
||||
|
@ -15,6 +15,7 @@ main.wait_timeout @solaris # Bug#11758972 2010-04-26 alik wait_tim
|
||||
|
||||
rpl.rpl_innodb_bug28430 # Bug#11754425
|
||||
rpl.rpl_row_sp011 @solaris # Bug#11753919 2011-07-25 sven Several test cases fail on Solaris with error Thread stack overrun
|
||||
rpl.rpl_spec_variables @solaris # Bug #17337114 2013-08-20 Luis Soares failing on pb2 with timeout for 'CHECK WARNINGS'
|
||||
|
||||
sys_vars.max_sp_recursion_depth_func @solaris # Bug#11753919 2010-01-20 alik Several test cases fail on Solaris with error Thread stack overrun
|
||||
sys_vars.wait_timeout_func # Bug#11750645 2010-04-26 alik wait_timeout_func fails
|
||||
|
@ -187,10 +187,9 @@ if (`SELECT HEX(@commands) = HEX('configure')`)
|
||||
}
|
||||
|
||||
#
|
||||
# Drops tables and synchronizes master and slave. Note that temporary
|
||||
# tables are not explitcily dropped as they will be dropped while
|
||||
# closing the connection.
|
||||
# Drops tables and synchronizes master and slave.
|
||||
#
|
||||
|
||||
if (`SELECT HEX(@commands) = HEX('clean')`)
|
||||
{
|
||||
connection master;
|
||||
@ -207,10 +206,15 @@ if (`SELECT HEX(@commands) = HEX('clean')`)
|
||||
|
||||
DROP TABLE IF EXISTS nt_error_2;
|
||||
|
||||
DROP TEMPORARY TABLE IF EXISTS tt_tmp_xx_1;
|
||||
DROP TEMPORARY TABLE IF EXISTS nt_tmp_xx_1;
|
||||
|
||||
--let $n= $tot_table
|
||||
while ($n)
|
||||
{
|
||||
--eval DROP TABLE IF EXISTS nt_$n
|
||||
--eval DROP TEMPORARY TABLE IF EXISTS tt_tmp_$n
|
||||
--eval DROP TEMPORARY TABLE IF EXISTS nt_tmp_$n
|
||||
--dec $n
|
||||
}
|
||||
|
||||
|
@ -113,7 +113,7 @@ FLUSH LOGS;
|
||||
--echo -------- switch to master --------
|
||||
connection master;
|
||||
FLUSH LOGS;
|
||||
|
||||
DROP TEMPORARY TABLE IF EXISTS mysqltest1.tmp2;
|
||||
DROP DATABASE mysqltest1;
|
||||
|
||||
--echo End of 5.1 tests
|
||||
|
@ -41,6 +41,9 @@ reset slave;
|
||||
source include/start_slave.inc;
|
||||
sync_with_master;
|
||||
show status like 'slave_open_temp_tables';
|
||||
connection master;
|
||||
drop temporary table if exists t1;
|
||||
sync_slave_with_master;
|
||||
|
||||
#
|
||||
#Bug#34654 RESET SLAVE does not clear LAST_IO_Err*
|
||||
|
@ -633,7 +633,7 @@ drop table t1;
|
||||
drop table bug29807;
|
||||
--disable_query_log
|
||||
call mtr.add_suppression("InnoDB: Error: table .test...bug29807. does not exist in the InnoDB internal");
|
||||
call mtr.add_suppression("InnoDB: Cannot open table test\/bug29807 from");
|
||||
call mtr.add_suppression("InnoDB: Cannot open table test/bug29807 from");
|
||||
--enable_query_log
|
||||
|
||||
|
||||
|
@ -82,5 +82,10 @@ BEGIN
|
||||
-- verify that no plugin changed its disabled/enabled state
|
||||
SELECT * FROM INFORMATION_SCHEMA.PLUGINS;
|
||||
|
||||
select * from information_schema.session_variables
|
||||
where variable_name = 'debug_sync';
|
||||
|
||||
show status like 'slave_open_temp_tables';
|
||||
|
||||
END||
|
||||
|
||||
|
66
mysql-test/include/search_pattern_in_file.inc
Normal file
66
mysql-test/include/search_pattern_in_file.inc
Normal file
@ -0,0 +1,66 @@
|
||||
# Purpose:
|
||||
# Simple search with Perl for a pattern in some file.
|
||||
#
|
||||
# The advantages compared to thinkable auxiliary constructs using the
|
||||
# mysqltest language and SQL are:
|
||||
# 1. We do not need a running MySQL server.
|
||||
# 2. SQL causes "noise" during debugging and increases the size of logs.
|
||||
# Perl code does not disturb at all.
|
||||
#
|
||||
# The environment variables SEARCH_FILE and SEARCH_PATTERN must be set
|
||||
# before sourcing this routine.
|
||||
#
|
||||
# In case of
|
||||
# - SEARCH_FILE and/or SEARCH_PATTERN is not set
|
||||
# - SEARCH_FILE cannot be opened
|
||||
# - SEARCH_FILE does not contain SEARCH_PATTERN
|
||||
# the test will abort immediate.
|
||||
# MTR will report something like
|
||||
# ....
|
||||
# worker[1] Using MTR_BUILD_THREAD 300, with reserved ports 13000..13009
|
||||
# main.1st [ pass ] 3
|
||||
# innodb.innodb_page_size [ fail ]
|
||||
# Test ended at 2011-11-11 18:15:58
|
||||
#
|
||||
# CURRENT_TEST: innodb.innodb_page_size
|
||||
# # ERROR: The file '<name>' does not contain the expected pattern <pattern>
|
||||
# mysqltest: In included file "./include/search_pattern_in_file.inc":
|
||||
# included from ./include/search_pattern_in_file.inc at line 36:
|
||||
# At line 25: command "perl" failed with error 255. my_errno=175
|
||||
#
|
||||
# The result from queries just before the failure was:
|
||||
# ...
|
||||
# - saving '<some path>' to '<some path>'
|
||||
# main.1st [ pass ] 2
|
||||
#
|
||||
# Typical use case (check invalid server startup options):
|
||||
# let $error_log= $MYSQLTEST_VARDIR/log/my_restart.err;
|
||||
# --error 0,1
|
||||
# --remove_file $error_log
|
||||
# let SEARCH_FILE= $error_log;
|
||||
# # Stop the server
|
||||
# let $restart_file= $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
|
||||
# --exec echo "wait" > $restart_file
|
||||
# --shutdown_server 10
|
||||
# --source include/wait_until_disconnected.inc
|
||||
#
|
||||
# --error 1
|
||||
# --exec $MYSQLD_CMD <whatever wrong setting> > $error_log 2>&1
|
||||
# # The server restart aborts
|
||||
# let SEARCH_PATTERN= \[ERROR\] Aborting;
|
||||
# --source include/search_pattern_in_file.inc
|
||||
#
|
||||
# Created: 2011-11-11 mleich
|
||||
#
|
||||
|
||||
perl;
|
||||
use strict;
|
||||
my $search_file= $ENV{'SEARCH_FILE'} or die "SEARCH_FILE not set";
|
||||
my $search_pattern= $ENV{'SEARCH_PATTERN'} or die "SEARCH_PATTERN not set";
|
||||
open(FILE, "$search_file") or die("Unable to open '$search_file': $!\n");
|
||||
read(FILE, my $file_content, 50000, 0);
|
||||
close(FILE);
|
||||
if ( not $file_content =~ m{$search_pattern} ) {
|
||||
die("# ERROR: The file '$search_file' does not contain the expected pattern $search_pattern\n->$file_content<-\n");
|
||||
}
|
||||
EOF
|
@ -4265,11 +4265,18 @@ sub run_testcase ($$) {
|
||||
#
|
||||
foreach my $option ($config->options_in_group("ENV"))
|
||||
{
|
||||
# Save old value to restore it before next time
|
||||
$old_env{$option->name()}= $ENV{$option->name()};
|
||||
my ($name, $val)= ($option->name(), $option->value());
|
||||
|
||||
mtr_verbose($option->name(), "=",$option->value());
|
||||
$ENV{$option->name()}= $option->value();
|
||||
# Save old value to restore it before next time
|
||||
$old_env{$name}= $ENV{$name};
|
||||
|
||||
unless (defined $val) {
|
||||
mtr_warning("Uninitialized value for ", $name,
|
||||
", group [ENV], file ", $current_config_name);
|
||||
} else {
|
||||
mtr_verbose($name, "=", $val);
|
||||
$ENV{$name}= $val;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
11
mysql-test/r/alter_table_autoinc-5574.result
Normal file
11
mysql-test/r/alter_table_autoinc-5574.result
Normal file
@ -0,0 +1,11 @@
|
||||
create table t1(a int(10)unsigned not null auto_increment primary key,
|
||||
b varchar(255) not null) engine=innodb default charset=utf8;
|
||||
insert into t1 values(1,'aaa'),(2,'bbb');
|
||||
alter table t1 auto_increment=1;
|
||||
insert into t1 values(NULL, 'ccc');
|
||||
select * from t1;
|
||||
a b
|
||||
1 aaa
|
||||
2 bbb
|
||||
3 ccc
|
||||
drop table t1;
|
@ -4,3 +4,15 @@ ALTER TABLE t1 RENAME TO t2, DISABLE KEYS;
|
||||
Warnings:
|
||||
Note 1031 Storage engine InnoDB of the table `test`.`t1` doesn't have this option
|
||||
DROP TABLE t2;
|
||||
CREATE TABLE t1 (
|
||||
col4 text NOT NULL,
|
||||
col2 int(11) NOT NULL DEFAULT '0',
|
||||
col3 int(11) DEFAULT NULL,
|
||||
extra int(11) DEFAULT NULL,
|
||||
KEY idx (col4(10))
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
|
||||
insert t1 values (repeat('1', 8193),3,1,1);
|
||||
insert t1 values (repeat('3', 8193),3,1,1);
|
||||
ALTER TABLE t1 ADD PRIMARY KEY (col4(10)) , ADD UNIQUE KEY uidx (col3);
|
||||
ERROR 23000: Duplicate entry '1' for key 'uidx'
|
||||
DROP TABLE t1;
|
||||
|
14
mysql-test/r/assign_key_cache-5405.result
Normal file
14
mysql-test/r/assign_key_cache-5405.result
Normal file
@ -0,0 +1,14 @@
|
||||
create table t1 (f int, key(f)) engine=myisam;
|
||||
set global kc1.key_buffer_size = 65536;
|
||||
set debug_sync='assign_key_cache_op_unlock wait_for op_locked';
|
||||
cache index t1 in kc1;
|
||||
set debug_sync='assign_key_cache_op_lock signal op_locked wait_for assigned';
|
||||
cache index t1 in kc1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 assign_to_keycache status OK
|
||||
set debug_sync='now signal assigned';
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 assign_to_keycache status OK
|
||||
drop table t1;
|
||||
set global kc1.key_buffer_size = 0;
|
||||
set debug_sync='reset';
|
@ -479,6 +479,28 @@ SELECT * FROM
|
||||
WHERE tmp.a;
|
||||
a b
|
||||
100 200
|
||||
#
|
||||
# MDEV-5356: Server crashes in Item_equal::contains on 2nd
|
||||
# execution of a PS
|
||||
#
|
||||
CREATE TABLE t1 (a INT, b INT);
|
||||
INSERT INTO t1 VALUES (1,2),(3,4);
|
||||
CREATE TABLE t2 (c INT);
|
||||
INSERT INTO t2 VALUES (5),(6);
|
||||
CREATE TABLE t3 (d INT);
|
||||
INSERT INTO t3 VALUES (7),(8);
|
||||
CREATE PROCEDURE pr()
|
||||
UPDATE t3,
|
||||
(SELECT c FROM
|
||||
(SELECT 1 FROM t1 WHERE a=72 AND NOT b) sq,
|
||||
t2
|
||||
) sq2
|
||||
SET d=sq2.c;
|
||||
CALL pr();
|
||||
CALL pr();
|
||||
CALL pr();
|
||||
drop procedure pr;
|
||||
drop table t1,t2,t3;
|
||||
# End of 5.3 tests
|
||||
#
|
||||
# Bug#58730 Assertion failed: table->key_read == 0 in close_thread_table,
|
||||
|
@ -2256,6 +2256,115 @@ Warnings:
|
||||
Note 1003 select 4 AS `a` from dual where (4 > 100) order by 1
|
||||
DROP VIEW v1;
|
||||
DROP TABLE t1;
|
||||
CREATE TABLE IF NOT EXISTS `galleries` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`name` varchar(100) NOT NULL,
|
||||
`year` int(11) DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `name` (`name`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||||
Warnings:
|
||||
Warning 1286 Unknown storage engine 'InnoDB'
|
||||
Warning 1266 Using storage engine MyISAM for table 'galleries'
|
||||
CREATE TABLE IF NOT EXISTS `pictures` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`name` varchar(100) NOT NULL,
|
||||
`width` float DEFAULT NULL,
|
||||
`height` float DEFAULT NULL,
|
||||
`year` int(4) DEFAULT NULL,
|
||||
`technique` varchar(50) DEFAULT NULL,
|
||||
`comment` varchar(2000) DEFAULT NULL,
|
||||
`gallery_id` int(11) NOT NULL,
|
||||
`type` int(11) NOT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `gallery_id` (`gallery_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;
|
||||
Warnings:
|
||||
Warning 1286 Unknown storage engine 'InnoDB'
|
||||
Warning 1266 Using storage engine MyISAM for table 'pictures'
|
||||
ALTER TABLE `pictures`
|
||||
ADD CONSTRAINT `pictures_ibfk_1` FOREIGN KEY (`gallery_id`) REFERENCES `galleries` (`id`);
|
||||
INSERT INTO `galleries` (`id`, `name`, `year`) VALUES
|
||||
(1, 'Quand le noir et blanc invite le taupe', 2013),
|
||||
(2, 'Une touche de couleur', 2012),
|
||||
(3, 'Éclats', 2011),
|
||||
(4, 'Gris béton', 2010),
|
||||
(5, 'Expression du spalter', 2010),
|
||||
(6, 'Zénitude', 2009),
|
||||
(7, 'La force du rouge', 2008),
|
||||
(8, 'Sphères', NULL),
|
||||
(9, 'Centre', 2009),
|
||||
(10, 'Nébuleuse', NULL);
|
||||
INSERT INTO `pictures` (`id`, `name`, `width`, `height`, `year`, `technique`, `comment`, `gallery_id`, `type`) VALUES
|
||||
(1, 'Éclaircie', 72.5, 100, NULL, NULL, NULL, 1, 1),
|
||||
(2, 'Architecture', 81, 100, NULL, NULL, NULL, 1, 1),
|
||||
(3, 'Nouveau souffle', 72.5, 100, NULL, NULL, NULL, 1, 1),
|
||||
(4, 'Échanges (2)', 89, 116, NULL, NULL, NULL, 1, 1),
|
||||
(5, 'Échanges', 89, 116, NULL, NULL, NULL, 1, 1),
|
||||
(6, 'Fenêtre de vie', 81, 116, NULL, NULL, NULL, 1, 1),
|
||||
(7, 'Architecture', 81, 100, NULL, NULL, NULL, 1, 1),
|
||||
(8, 'Nouveau souffle (2)', 72.5, 100, NULL, NULL, NULL, 1, 1),
|
||||
(9, 'Fluidité', 89, 116, NULL, NULL, NULL, 1, 1),
|
||||
(10, 'Nouveau Monde', 89, 125, NULL, NULL, NULL, 1, 1),
|
||||
(11, 'Mirage', 73, 100, NULL, NULL, NULL, 1, 1),
|
||||
(12, 'Équilibre', 72.5, 116, NULL, NULL, NULL, 2, 1),
|
||||
(13, 'Fusion', 72.5, 116, NULL, NULL, NULL, 2, 1),
|
||||
(14, 'Étincelles', NULL, NULL, NULL, NULL, NULL, 3, 1),
|
||||
(15, 'Régénérescence', NULL, NULL, NULL, NULL, NULL, 3, 1),
|
||||
(16, 'Chaleur', 80, 80, NULL, NULL, NULL, 4, 1),
|
||||
(17, 'Création', 90, 90, NULL, NULL, NULL, 4, 1),
|
||||
(18, 'Horizon', 92, 73, NULL, NULL, NULL, 4, 1),
|
||||
(19, 'Labyrinthe', 81, 100, NULL, NULL, NULL, 4, 1),
|
||||
(20, 'Miroir', 80, 116, NULL, NULL, NULL, 5, 1),
|
||||
(21, 'Libération', 81, 116, NULL, NULL, NULL, 5, 1),
|
||||
(22, 'Éclats', 81, 116, NULL, NULL, NULL, 5, 1),
|
||||
(23, 'Zénitude', 116, 89, NULL, NULL, NULL, 6, 1),
|
||||
(24, 'Écritures lointaines', 90, 90, NULL, NULL, NULL, 7, 1),
|
||||
(25, 'Émergence', 80, 80, NULL, NULL, NULL, 7, 1),
|
||||
(26, 'Liberté', 50, 50, NULL, NULL, NULL, 7, 1),
|
||||
(27, 'Silhouettes amérindiennes', 701, 70, NULL, NULL, NULL, 7, 1),
|
||||
(28, 'Puissance', 81, 100, NULL, NULL, NULL, 8, 1),
|
||||
(29, 'Source', 73, 116, NULL, NULL, NULL, 8, 1),
|
||||
(30, 'Comme une ville qui prend vie', 50, 100, 2008, NULL, NULL, 9, 1),
|
||||
(31, 'Suspension azur', 80, 80, NULL, NULL, NULL, 9, 1),
|
||||
(32, 'Nébuleuse', 70, 70, NULL, NULL, NULL, 10, 1),
|
||||
(33, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2),
|
||||
(34, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2),
|
||||
(35, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2),
|
||||
(36, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2),
|
||||
(37, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2),
|
||||
(38, 'Œuvre commandée 120 P', 114, 195, NULL, NULL, NULL, 1, 2);
|
||||
explain
|
||||
SELECT g.id AS gallery_id,
|
||||
g.name AS gallery_name,
|
||||
p.id AS picture_id,
|
||||
p.name AS picture_name,
|
||||
g.p_random AS r1,
|
||||
g.p_random AS r2,
|
||||
g.p_random AS r3
|
||||
FROM
|
||||
(
|
||||
SELECT gal.id,
|
||||
gal.name,
|
||||
(
|
||||
SELECT pi.id
|
||||
FROM pictures pi
|
||||
WHERE pi.gallery_id = gal.id
|
||||
ORDER BY RAND()
|
||||
LIMIT 1
|
||||
) AS p_random
|
||||
FROM galleries gal
|
||||
) g
|
||||
LEFT JOIN pictures p
|
||||
ON p.id = g.p_random
|
||||
ORDER BY gallery_name ASC
|
||||
;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 PRIMARY <derived2> ALL NULL NULL NULL NULL 2 Using filesort
|
||||
1 PRIMARY p eq_ref PRIMARY PRIMARY 4 g.p_random 1 Using where
|
||||
2 DERIVED gal ALL NULL NULL NULL NULL 10
|
||||
3 DEPENDENT SUBQUERY pi ref gallery_id gallery_id 4 test.gal.id 4 Using temporary; Using filesort
|
||||
drop table galleries, pictures;
|
||||
#
|
||||
# end of 5.3 tests
|
||||
#
|
||||
|
34
mysql-test/r/flush-innodb-notembedded.result
Normal file
34
mysql-test/r/flush-innodb-notembedded.result
Normal file
@ -0,0 +1,34 @@
|
||||
# Test 7: Check privileges required.
|
||||
#
|
||||
CREATE DATABASE db1;
|
||||
CREATE TABLE db1.t1 (a INT) engine= InnoDB;
|
||||
GRANT RELOAD, SELECT, LOCK TABLES ON *.* TO user1@localhost;
|
||||
GRANT CREATE, DROP ON *.* TO user2@localhost;
|
||||
GRANT RELOAD, SELECT ON *.* TO user3@localhost;
|
||||
GRANT SELECT, LOCK TABLES ON *.* TO user4@localhost;
|
||||
GRANT RELOAD, LOCK TABLES ON *.* TO user5@localhost;
|
||||
# Connection con1 as user1
|
||||
FLUSH TABLE db1.t1 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
# Connection con1 as user2
|
||||
FLUSH TABLE db1.t1 FOR EXPORT;
|
||||
ERROR 42000: Access denied; you need (at least one of) the RELOAD privilege(s) for this operation
|
||||
# Connection default
|
||||
# Connection con1 as user3
|
||||
FLUSH TABLE db1.t1 FOR EXPORT;
|
||||
ERROR 42000: Access denied for user 'user3'@'localhost' to database 'db1'
|
||||
# Connection default
|
||||
# Connection con1 as user4
|
||||
FLUSH TABLE db1.t1 FOR EXPORT;
|
||||
ERROR 42000: Access denied; you need (at least one of) the RELOAD privilege(s) for this operation
|
||||
# Connection default
|
||||
# Connection con1 as user5
|
||||
FLUSH TABLE db1.t1 FOR EXPORT;
|
||||
ERROR 42000: SELECT command denied to user 'user5'@'localhost' for table 't1'
|
||||
# Connection default
|
||||
DROP USER user1@localhost, user2@localhost, user3@localhost,
|
||||
user4@localhost, user5@localhost;
|
||||
DROP TABLE db1.t1;
|
||||
DROP DATABASE db1;
|
||||
# End of 5.6 tests
|
@ -3,3 +3,297 @@ UNLOCK TABLES;
|
||||
CREATE TABLE t1 ( m MEDIUMTEXT ) ENGINE=InnoDB;
|
||||
INSERT INTO t1 VALUES ( REPEAT('i',1048576) );
|
||||
DROP TABLE t1;
|
||||
|
||||
#
|
||||
# WL#6168: FLUSH TABLES ... FOR EXPORT -- parser
|
||||
#
|
||||
|
||||
# Requires innodb_file_per_table
|
||||
SET @old_innodb_file_per_table= @@GLOBAL.innodb_file_per_table;
|
||||
SET GLOBAL innodb_file_per_table= 1;
|
||||
# new "EXPORT" keyword is a valid user variable name:
|
||||
SET @export = 10;
|
||||
# new "EXPORT" keyword is a valid SP parameter name:
|
||||
CREATE PROCEDURE p1(export INT) BEGIN END;
|
||||
DROP PROCEDURE p1;
|
||||
# new "EXPORT" keyword is a valid local variable name:
|
||||
CREATE PROCEDURE p1()
|
||||
BEGIN
|
||||
DECLARE export INT;
|
||||
END|
|
||||
DROP PROCEDURE p1;
|
||||
# new "EXPORT" keyword is a valid SP name:
|
||||
CREATE PROCEDURE export() BEGIN END;
|
||||
DROP PROCEDURE export;
|
||||
# new FLUSH TABLES ... FOR EXPORT syntax:
|
||||
FLUSH TABLES FOR EXPORT;
|
||||
ERROR 42000: No tables used near 'FOR EXPORT' at line 1
|
||||
FLUSH TABLES WITH EXPORT;
|
||||
ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'EXPORT' at line 1
|
||||
CREATE TABLE t1 (i INT) engine=InnoDB;
|
||||
CREATE TABLE t2 LIKE t1;
|
||||
FLUSH TABLES t1,t2 WITH EXPORT;
|
||||
ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'EXPORT' at line 1
|
||||
FLUSH TABLES t1, t2 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# case check
|
||||
FLUSH TABLES t1, t2 for ExPoRt;
|
||||
UNLOCK TABLES;
|
||||
# With LOCAL keyword
|
||||
FLUSH LOCAL TABLES t1, t2 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# Tables with fully qualified names
|
||||
FLUSH LOCAL TABLES test.t1, test.t2 for ExPoRt;
|
||||
UNLOCK TABLES;
|
||||
DROP TABLES t1, t2;
|
||||
# new "EXPORT" keyword is a valid table name:
|
||||
CREATE TABLE export (i INT) engine=InnoDB;
|
||||
# it's ok to lock the "export" table for export:
|
||||
FLUSH TABLE export FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE export;
|
||||
#
|
||||
# WL#6169 FLUSH TABLES ... FOR EXPORT -- runtime
|
||||
#
|
||||
# Test 1: Views, temporary tables, non-existent tables
|
||||
#
|
||||
CREATE VIEW v1 AS SELECT 1;
|
||||
CREATE TEMPORARY TABLE t1 (a INT);
|
||||
FLUSH TABLES v1 FOR EXPORT;
|
||||
ERROR HY000: 'test.v1' is not BASE TABLE
|
||||
FLUSH TABLES t1 FOR EXPORT;
|
||||
ERROR 42S02: Table 'test.t1' doesn't exist
|
||||
FLUSH TABLES non_existent FOR EXPORT;
|
||||
ERROR 42S02: Table 'test.non_existent' doesn't exist
|
||||
DROP TEMPORARY TABLE t1;
|
||||
DROP VIEW v1;
|
||||
# Test 2: Blocked by update transactions, blocks updates.
|
||||
#
|
||||
CREATE TABLE t1 (a INT PRIMARY KEY, b INT) engine= InnoDB;
|
||||
CREATE TABLE t2 (a INT) engine= InnoDB;
|
||||
# Connection con1
|
||||
START TRANSACTION;
|
||||
INSERT INTO t1 VALUES (1, 1);
|
||||
# Connection default
|
||||
# Should be blocked
|
||||
# Sending:
|
||||
FLUSH TABLES t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
COMMIT;
|
||||
# Connection default
|
||||
# Reaping: FLUSH TABLES t1 FOR EXPORT
|
||||
# Connection con1
|
||||
# Should not be blocked
|
||||
INSERT INTO t2 VALUES (1);
|
||||
# Should be blocked
|
||||
# Sending:
|
||||
INSERT INTO t1 VALUES (2, 2);
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
# Connection con1
|
||||
# Reaping: INSERT INTO t1 VALUES (2, 2);
|
||||
# Test 3: Read operations should not be affected.
|
||||
#
|
||||
START TRANSACTION;
|
||||
SELECT * FROM t1;
|
||||
a b
|
||||
1 1
|
||||
2 2
|
||||
# Connection default
|
||||
# Should not be blocked
|
||||
FLUSH TABLES t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
COMMIT;
|
||||
# Should not be blocked
|
||||
SELECT * FROM t1;
|
||||
a b
|
||||
1 1
|
||||
2 2
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
# Test 4: Blocked by DDL, blocks DDL.
|
||||
#
|
||||
START TRANSACTION;
|
||||
SELECT * FROM t1;
|
||||
a b
|
||||
1 1
|
||||
2 2
|
||||
# Connection con2
|
||||
# Sending:
|
||||
ALTER TABLE t1 ADD INDEX i1(b);
|
||||
# Connection con1
|
||||
# Should be blocked
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# Connection default
|
||||
COMMIT;
|
||||
# Connection con2
|
||||
# Reaping ALTER TABLE ...
|
||||
# Connection con1
|
||||
# Reaping FLUSH TABLE t1 FOR EXPORT
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# Connection con2
|
||||
# Should be blocked
|
||||
DROP TABLE t1;
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
# Connection con2
|
||||
# Reaping DROP TABLE t1
|
||||
# Connection default
|
||||
DROP TABLE t2;
|
||||
# Test 5: Compatibilty with FLUSH TABLES WITH READ LOCK
|
||||
#
|
||||
CREATE TABLE t1(a INT) engine= InnoDB;
|
||||
FLUSH TABLES WITH READ LOCK;
|
||||
# Connection con1
|
||||
# This should not block
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE t1;
|
||||
# Test 6: Unsupported storage engines.
|
||||
#
|
||||
CREATE TABLE t1(a INT) engine= MEMORY;
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
ERROR HY000: Storage engine MEMORY of the table `test`.`t1` doesn't have this option
|
||||
DROP TABLE t1;
|
||||
# Connection con1
|
||||
# Connection defalt
|
||||
# Test 7: Check privileges required.
|
||||
# in flush-innodb-notembedded.test
|
||||
# Test 8: FLUSH TABLE <table_list> FOR EXPORT is incompatible
|
||||
# with itself (to avoid race conditions in metadata
|
||||
# file handling).
|
||||
#
|
||||
CREATE TABLE t1 (a INT) engine= InnoDB;
|
||||
CREATE TABLE t2 (a INT) engine= InnoDB;
|
||||
# Connection con1
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# Connection default
|
||||
# This should not block
|
||||
FLUSH TABLE t2 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# This should block
|
||||
# Sending:
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
# Reaping: FLUSH TABLE t1 FOR EXPORT
|
||||
UNLOCK TABLES;
|
||||
# Test 9: LOCK TABLES ... READ is not affected
|
||||
#
|
||||
LOCK TABLE t1 READ;
|
||||
# Connection con1
|
||||
# Should not block
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
# Should not block
|
||||
LOCK TABLE t1 READ;
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
UNLOCK TABLES;
|
||||
# Connection con1
|
||||
# Connection default
|
||||
DROP TABLE t1, t2;
|
||||
# Test 10: Lock is released if transaction is started after doing
|
||||
# 'flush table..' in same session
|
||||
CREATE TABLE t1 ( i INT ) ENGINE = Innodb;
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
# error as active locks already exist
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
ERROR HY000: Can't execute the given command because you have active locked tables or an active transaction
|
||||
# active locks will be released due to start transaction
|
||||
START TRANSACTION;
|
||||
# passes as start transaction released ealier locks
|
||||
FLUSH TABLE t1 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE t1;
|
||||
# Test 11: Test 'flush table with fully qualified table names
|
||||
# and with syntax local/NO_WRITE_TO_BINLOG
|
||||
# Connection con1
|
||||
# Connection default
|
||||
CREATE TABLE t1 ( i INT ) ENGINE = Innodb;
|
||||
INSERT INTO t1 VALUES (100),(200);
|
||||
FLUSH LOCAL TABLES test.t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
# Should be blocked
|
||||
# Sending:
|
||||
FLUSH LOCAL TABLES t1 FOR EXPORT;
|
||||
# Connection default
|
||||
UNLOCK TABLE;
|
||||
# Connection con1
|
||||
# Reaping: FLUSH LOCAL TABLES t1 FOR EXPORT
|
||||
SELECT * FROM t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
# Connection default
|
||||
# Should be blocked
|
||||
# Sending:
|
||||
FLUSH NO_WRITE_TO_BINLOG TABLES test.t1 FOR EXPORT;
|
||||
# Connection con1
|
||||
UNLOCK TABLES;
|
||||
# Connection default
|
||||
# Reaping: FLUSH NO_WRITE_TO_BINLOG TABLES test.t1 FOR EXPORT
|
||||
SELECT * FROM t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
UNLOCK TABLE;
|
||||
DROP TABLE t1;
|
||||
# Test 12: Active transaction get committed if user execute
|
||||
# "FLUSH TABLE ... FOR EXPORT" or "LOCK TABLE.."
|
||||
# Connection default
|
||||
CREATE TABLE t1 ( i INT ) ENGINE = Innodb;
|
||||
INSERT INTO t1 VALUES (100),(200);
|
||||
START TRANSACTION;
|
||||
INSERT INTO t1 VALUES (300);
|
||||
# 'flush table..' commit active transaction from same session
|
||||
FLUSH LOCAL TABLES test.t1 FOR EXPORT;
|
||||
ROLLBACK;
|
||||
SELECT * FROM t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
START TRANSACTION;
|
||||
INSERT INTO t1 VALUES (400);
|
||||
# 'lock table ..' commit active transaction from same session
|
||||
LOCK TABLES test.t1 READ;
|
||||
ROLLBACK;
|
||||
SELECT * FROM t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
400
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE t1;
|
||||
# Test 13: Verify "FLUSH TABLE ... FOR EXPORT" and "LOCK TABLE.."
|
||||
# in same session
|
||||
# Connection default
|
||||
CREATE TABLE t1 ( i INT ) ENGINE = Innodb;
|
||||
# Lock table
|
||||
LOCK TABLES test.t1 WRITE;
|
||||
# 'lock table ..' completes even if table lock is acquired
|
||||
# in same session using 'lock table'. Previous locks are released.
|
||||
LOCK TABLES test.t1 READ;
|
||||
# 'flush table ..' gives error if table lock is acquired
|
||||
# in same session using 'lock table ..'
|
||||
FLUSH TABLES test.t1 FOR EXPORT;
|
||||
ERROR HY000: Can't execute the given command because you have active locked tables or an active transaction
|
||||
# 'lock table ..' completes even if table lock is acquired
|
||||
# in same session using 'flush table'. Previous locks are released.
|
||||
LOCK TABLES test.t1 WRITE;
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE t1;
|
||||
# Reset innodb_file_per_table
|
||||
SET GLOBAL innodb_file_per_table= @old_innodb_file_per_table;
|
||||
# End of 5.6 tests
|
||||
|
@ -2375,6 +2375,40 @@ SELECT EXTRACT(DAY FROM TIME('1 02:00:00')), EXTRACT(DAY FROM TIME('26:00:00'));
|
||||
EXTRACT(DAY FROM TIME('1 02:00:00')) EXTRACT(DAY FROM TIME('26:00:00'))
|
||||
1 1
|
||||
#
|
||||
# MDEV-5458 RQG hits 'sql/tztime.cc:799: my_time_t sec_since_epoch(int, int, int, int, int, int): Assertion `mon > 0 && mon < 13' failed.'
|
||||
#
|
||||
SET TIMESTAMP=UNIX_TIMESTAMP('2014-01-22 18:19:20');
|
||||
CREATE TABLE t1 (t TIME);
|
||||
INSERT INTO t1 VALUES ('03:22:30'),('18:30:05');
|
||||
SELECT CONVERT_TZ(GREATEST(t, CURRENT_DATE()), '+02:00', '+10:00') FROM t1;
|
||||
CONVERT_TZ(GREATEST(t, CURRENT_DATE()), '+02:00', '+10:00')
|
||||
NULL
|
||||
NULL
|
||||
Warnings:
|
||||
Warning 1292 Truncated incorrect time value: '1296:00:00'
|
||||
Warning 1292 Incorrect datetime value: '838:59:59'
|
||||
Warning 1292 Truncated incorrect time value: '1296:00:00'
|
||||
Warning 1292 Incorrect datetime value: '838:59:59'
|
||||
SELECT GREATEST(t, CURRENT_DATE()) FROM t1;
|
||||
GREATEST(t, CURRENT_DATE())
|
||||
838:59:59
|
||||
838:59:59
|
||||
Warnings:
|
||||
Warning 1292 Truncated incorrect time value: '1296:00:00'
|
||||
Warning 1292 Truncated incorrect time value: '1296:00:00'
|
||||
DROP TABLE t1;
|
||||
SET TIMESTAMP=DEFAULT;
|
||||
#
|
||||
# MDEV-5504 Server crashes in String::length on SELECT with MONTHNAME, GROUP BY, ROLLUP
|
||||
#
|
||||
CREATE TABLE t1 (i INT);
|
||||
INSERT INTO t1 VALUES (1),(2);
|
||||
SELECT 1 FROM t1 GROUP BY MONTHNAME(0) WITH ROLLUP;
|
||||
1
|
||||
1
|
||||
1
|
||||
DROP TABLE t1;
|
||||
#
|
||||
# MDEV-4838 Wrong metadata for DATE_ADD('string', INVERVAL)
|
||||
#
|
||||
SELECT DATE_ADD('2011-01-02 12:13:14', INTERVAL 1 MINUTE);
|
||||
@ -2382,3 +2416,60 @@ Catalog Database Table Table_alias Column Column_alias Type Length Max length Is
|
||||
def DATE_ADD('2011-01-02 12:13:14', INTERVAL 1 MINUTE) 254 19 19 Y 0 0 8
|
||||
DATE_ADD('2011-01-02 12:13:14', INTERVAL 1 MINUTE)
|
||||
2011-01-02 12:14:14
|
||||
#
|
||||
# MDEV-5450 Assertion `cached_field_ type == MYSQL_TYPE_STRING || ltime.time_type == MYSQL_TIMESTAMP_NONE || mysql_type_to_time_type(cached_field_type) == ltime.time_type' fails with IF, ISNULL, ADDDATE
|
||||
#
|
||||
CREATE TABLE t1 (a DATETIME, b DATE);
|
||||
INSERT INTO t1 VALUES (NULL, '2012-12-21');
|
||||
SELECT IF(1,ADDDATE(IFNULL(a,b),0),1) FROM t1;
|
||||
IF(1,ADDDATE(IFNULL(a,b),0),1)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDDATE(IFNULL(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(IFNULL(a,b),0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDDATE(COALESCE(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(COALESCE(a,b),0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDDATE(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
SELECT IF(1,ADDTIME(IFNULL(a,b),0),1) FROM t1;
|
||||
IF(1,ADDTIME(IFNULL(a,b),0),1)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDTIME(IFNULL(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(IFNULL(a,b),0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDTIME(COALESCE(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(COALESCE(a,b),0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
SELECT CAST(ADDTIME(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR)
|
||||
2012-12-21 00:00:00
|
||||
DROP TABLE t1;
|
||||
CREATE TABLE t1 (a DATETIME, b TIME);
|
||||
INSERT INTO t1 VALUES (NULL, '00:20:12');
|
||||
SELECT IF(1,ADDDATE(IFNULL(a,b),0),1) FROM t1;
|
||||
IF(1,ADDDATE(IFNULL(a,b),0),1)
|
||||
0000-00-00 00:20:12
|
||||
SELECT CAST(ADDDATE(IFNULL(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(IFNULL(a,b),0) AS CHAR)
|
||||
0000-00-00 00:20:12
|
||||
SELECT CAST(ADDDATE(COALESCE(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(COALESCE(a,b),0) AS CHAR)
|
||||
0000-00-00 00:20:12
|
||||
SELECT CAST(ADDDATE(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR) FROM t1;
|
||||
CAST(ADDDATE(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR)
|
||||
0000-00-00 00:20:12
|
||||
SELECT IF(1,ADDTIME(IFNULL(a,b),0),1) FROM t1;
|
||||
IF(1,ADDTIME(IFNULL(a,b),0),1)
|
||||
NULL
|
||||
SELECT CAST(ADDTIME(IFNULL(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(IFNULL(a,b),0) AS CHAR)
|
||||
NULL
|
||||
SELECT CAST(ADDTIME(COALESCE(a,b),0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(COALESCE(a,b),0) AS CHAR)
|
||||
NULL
|
||||
SELECT CAST(ADDTIME(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR) FROM t1;
|
||||
CAST(ADDTIME(CASE WHEN 0 THEN a ELSE b END,0) AS CHAR)
|
||||
NULL
|
||||
DROP TABLE t1;
|
||||
|
@ -1957,12 +1957,12 @@ UNIQUE INDEX idx (col1));
|
||||
INSERT INTO t1 VALUES (1),(2),(3),(4),(5),(6),(7),(8),(9),(10),
|
||||
(11),(12),(13),(14),(15),(16),(17),(18),(19),(20);
|
||||
EXPLAIN SELECT col1 AS field1, col1 AS field2
|
||||
FROM t1 GROUP BY field1, field2;;
|
||||
FROM t1 GROUP BY field1, field2+0;;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index; Using temporary; Using filesort
|
||||
FLUSH STATUS;
|
||||
SELECT col1 AS field1, col1 AS field2
|
||||
FROM t1 GROUP BY field1, field2;;
|
||||
FROM t1 GROUP BY field1, field2+0;;
|
||||
field1 field2
|
||||
1 1
|
||||
2 2
|
||||
@ -2054,8 +2054,12 @@ field1 field2
|
||||
explain
|
||||
select col1 f1, col1 f2 from t1 order by f2, f1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index
|
||||
explain
|
||||
select col1 f1, col1 f2 from t1 order by f2, f1+0;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index; Using filesort
|
||||
select col1 f1, col1 f2 from t1 order by f2, f1;
|
||||
select col1 f1, col1 f2 from t1 order by f2, f1+0;
|
||||
f1 f2
|
||||
1 1
|
||||
2 2
|
||||
@ -2080,7 +2084,7 @@ f1 f2
|
||||
explain
|
||||
select col1 f1, col1 f2 from t1 group by f2 order by f2, f1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index; Using temporary; Using filesort
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index
|
||||
select col1 f1, col1 f2 from t1 group by f2 order by f2, f1;
|
||||
f1 f2
|
||||
1 1
|
||||
@ -2106,7 +2110,7 @@ f1 f2
|
||||
explain
|
||||
select col1 f1, col1 f2 from t1 group by f1, f2 order by f2, f1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index; Using temporary; Using filesort
|
||||
1 SIMPLE t1 index NULL idx 5 NULL 20 Using index
|
||||
select col1 f1, col1 f2 from t1 group by f1, f2 order by f2, f1;
|
||||
f1 f2
|
||||
1 1
|
||||
@ -2137,10 +2141,10 @@ INSERT INTO t2(col1, col2) VALUES
|
||||
(1,20),(2,19),(3,18),(4,17),(5,16),(6,15),(7,14),(8,13),(9,12),(10,11),
|
||||
(11,10),(12,9),(13,8),(14,7),(15,6),(16,5),(17,4),(18,3),(19,2),(20,1);
|
||||
explain
|
||||
select col1 f1, col2 f2, col1 f3 from t2 group by f1, f2, f3;
|
||||
select col1 f1, col2 f2, col1 f3 from t2 group by f1, f2, f3+0;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 index NULL idx 10 NULL 20 Using index; Using temporary; Using filesort
|
||||
select col1 f1, col2 f2, col1 f3 from t2 group by f1, f2, f3;
|
||||
select col1 f1, col2 f2, col1 f3 from t2 group by f1, f2, f3+0;
|
||||
f1 f2 f3
|
||||
1 20 1
|
||||
2 19 2
|
||||
@ -2163,10 +2167,10 @@ f1 f2 f3
|
||||
19 2 19
|
||||
20 1 20
|
||||
explain
|
||||
select col1 f1, col2 f2, col1 f3 from t2 order by f1, f2, f3;
|
||||
select col1 f1, col2 f2, col1 f3 from t2 order by f1, f2, f3+0;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 index NULL idx 10 NULL 20 Using index; Using filesort
|
||||
select col1 f1, col2 f2, col1 f3 from t2 order by f1, f2, f3;
|
||||
select col1 f1, col2 f2, col1 f3 from t2 order by f1, f2, f3+0;
|
||||
f1 f2 f3
|
||||
1 20 1
|
||||
2 19 2
|
||||
@ -2470,32 +2474,6 @@ v 2v,2v
|
||||
NULL 1c,2v,2v
|
||||
DROP TABLE t1,t2;
|
||||
#
|
||||
# Test of MDEV-4002
|
||||
#
|
||||
CREATE TABLE t1 (
|
||||
pk INT NOT NULL PRIMARY KEY,
|
||||
d1 DOUBLE,
|
||||
d2 DOUBLE,
|
||||
i INT NOT NULL DEFAULT '0',
|
||||
KEY (i)
|
||||
) ENGINE=InnoDB;
|
||||
INSERT INTO t1 VALUES (1,1.0,1.1,1),(2,2.0,2.2,2);
|
||||
PREPARE stmt FROM "
|
||||
SELECT DISTINCT i, GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
FROM t1 a1 NATURAL JOIN t1 a2 GROUP BY i WITH ROLLUP
|
||||
";
|
||||
EXECUTE stmt;
|
||||
i GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
1 11.1
|
||||
2 22.2
|
||||
NULL 11.1,22.2
|
||||
EXECUTE stmt;
|
||||
i GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
1 11.1
|
||||
2 22.2
|
||||
NULL 11.1,22.2
|
||||
DROP TABLE t1;
|
||||
#
|
||||
# Bug #58782
|
||||
# Missing rows with SELECT .. WHERE .. IN subquery
|
||||
# with full GROUP BY and no aggr
|
||||
|
@ -1,3 +1,4 @@
|
||||
set @save_ext_key_optimizer_switch=@@optimizer_switch;
|
||||
#
|
||||
# MDEV-3992 Server crash or valgrind errors in test_if_skip_sort_order/test_if_cheaper_ordering
|
||||
# on GROUP BY with indexes on InnoDB table
|
||||
@ -7,13 +8,14 @@ pk INT PRIMARY KEY,
|
||||
a VARCHAR(1) NOT NULL,
|
||||
KEY (pk)
|
||||
) ENGINE=InnoDB;
|
||||
set optimizer_switch='extended_keys=on';
|
||||
INSERT INTO t1 VALUES (1,'a'),(2,'b');
|
||||
EXPLAIN
|
||||
SELECT COUNT(*), pk field1, pk AS field2
|
||||
FROM t1 WHERE a = 'r' OR pk = 183
|
||||
GROUP BY field1, field2;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index PRIMARY,pk pk 4 NULL 2 Using where
|
||||
1 SIMPLE t1 index PRIMARY,pk PRIMARY 4 NULL 2 Using where
|
||||
SELECT COUNT(*), pk field1, pk AS field2
|
||||
FROM t1 WHERE a = 'r' OR pk = 183
|
||||
GROUP BY field1, field2;
|
||||
@ -22,9 +24,36 @@ EXPLAIN
|
||||
SELECT COUNT(*), pk field1 FROM t1
|
||||
WHERE a = 'r' OR pk = 183 GROUP BY field1, field1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index PRIMARY,pk pk 4 NULL 2 Using where
|
||||
1 SIMPLE t1 index PRIMARY,pk PRIMARY 4 NULL 2 Using where
|
||||
SELECT COUNT(*), pk field1 FROM t1
|
||||
WHERE a = 'r' OR pk = 183 GROUP BY field1, field1;
|
||||
COUNT(*) field1
|
||||
drop table t1;
|
||||
set optimizer_switch=@save_ext_key_optimizer_switch;
|
||||
#
|
||||
# MDEV-4002 Server crash or valgrind errors in Item_func_group_concat::setup and Item_func_group_concat::add
|
||||
#
|
||||
CREATE TABLE t1 (
|
||||
pk INT NOT NULL PRIMARY KEY,
|
||||
d1 DOUBLE,
|
||||
d2 DOUBLE,
|
||||
i INT NOT NULL DEFAULT '0',
|
||||
KEY (i)
|
||||
) ENGINE=InnoDB;
|
||||
INSERT INTO t1 VALUES (1,1.0,1.1,1),(2,2.0,2.2,2);
|
||||
PREPARE stmt FROM "
|
||||
SELECT DISTINCT i, GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
FROM t1 a1 NATURAL JOIN t1 a2 GROUP BY i WITH ROLLUP
|
||||
";
|
||||
EXECUTE stmt;
|
||||
i GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
1 11.1
|
||||
2 22.2
|
||||
NULL 11.1,22.2
|
||||
EXECUTE stmt;
|
||||
i GROUP_CONCAT( d1, d2 ORDER BY d1, d2 )
|
||||
1 11.1
|
||||
2 22.2
|
||||
NULL 11.1,22.2
|
||||
DROP TABLE t1;
|
||||
End of 5.5 tests
|
||||
|
6
mysql-test/r/group_by_null.result
Normal file
6
mysql-test/r/group_by_null.result
Normal file
@ -0,0 +1,6 @@
|
||||
create table t1 (a int);
|
||||
insert into t1 values (1),(2);
|
||||
select max('foo') from t1 group by values(a), extractvalue('bar','qux') order by "v";
|
||||
max('foo')
|
||||
foo
|
||||
drop table t1;
|
@ -1,7 +1,7 @@
|
||||
DROP TABLE IF EXISTS t0,t1,t2,t3,t4,t5;
|
||||
DROP VIEW IF EXISTS v1;
|
||||
#
|
||||
# Bug#18925: subqueries with MIN/MAX functions on INFORMARTION_SCHEMA
|
||||
# Bug#18925: subqueries with MIN/MAX functions on INFORMATION_SCHEMA
|
||||
#
|
||||
SELECT t.table_name, c1.column_name
|
||||
FROM information_schema.tables t
|
||||
@ -58,8 +58,8 @@ USER_PRIVILEGES GRANTEE
|
||||
USER_STATISTICS USER
|
||||
VIEWS TABLE_SCHEMA
|
||||
XTRADB_INTERNAL_HASH_TABLES INTERNAL_HASH_TABLE_NAME
|
||||
XTRADB_RSEG rseg_id
|
||||
XTRADB_READ_VIEW READ_VIEW_UNDO_NUMBER
|
||||
XTRADB_RSEG rseg_id
|
||||
SELECT t.table_name, c1.column_name
|
||||
FROM information_schema.tables t
|
||||
INNER JOIN
|
||||
@ -115,5 +115,5 @@ USER_PRIVILEGES GRANTEE
|
||||
USER_STATISTICS USER
|
||||
VIEWS TABLE_SCHEMA
|
||||
XTRADB_INTERNAL_HASH_TABLES INTERNAL_HASH_TABLE_NAME
|
||||
XTRADB_RSEG rseg_id
|
||||
XTRADB_READ_VIEW READ_VIEW_UNDO_NUMBER
|
||||
XTRADB_RSEG rseg_id
|
||||
|
@ -991,6 +991,54 @@ id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 ref page_timestamp page_timestamp 4 const 10 Using where
|
||||
1 SIMPLE t3 eq_ref PRIMARY PRIMARY 4 test.t2.rev_text_id 1
|
||||
DROP TABLE t1,t2,t3;
|
||||
#
|
||||
# MDEV-5424 SELECT using ORDER BY DESC and LIMIT produces unexpected
|
||||
# results (InnoDB/XtraDB)
|
||||
#
|
||||
create table t1 (a bigint not null unique auto_increment, b varchar(10), primary key (a), key (b(2))) engine = myisam default character set utf8;
|
||||
create table t2 (a bigint not null unique auto_increment, b varchar(10), primary key (a), key (b(2))) engine = innodb default character set utf8;
|
||||
insert into t1 (b) values (null), (null), (null);
|
||||
insert into t2 (b) values (null), (null), (null);
|
||||
set optimizer_switch='extended_keys=on';
|
||||
explain select a from t1 where b is null order by a desc limit 2;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ref b b 9 const 2 Using where; Using filesort
|
||||
select a from t1 where b is null order by a desc limit 2;
|
||||
a
|
||||
3
|
||||
2
|
||||
explain select a from t2 where b is null order by a desc limit 2;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 range b b 9 NULL 3 Using where; Using filesort
|
||||
select a from t2 where b is null order by a desc limit 2;
|
||||
a
|
||||
3
|
||||
2
|
||||
set optimizer_switch='extended_keys=off';
|
||||
explain select a from t2 where b is null order by a desc limit 2;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 range b b 9 NULL 3 Using where; Using filesort
|
||||
select a from t2 where b is null order by a desc limit 2;
|
||||
a
|
||||
3
|
||||
2
|
||||
explain select a from t2 where b is null order by a desc;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 index b PRIMARY 8 NULL 3 Using where
|
||||
select a from t2 where b is null order by a desc;
|
||||
a
|
||||
3
|
||||
2
|
||||
1
|
||||
explain select a from t2 where b is null order by a desc,a,a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 index b PRIMARY 8 NULL 3 Using where
|
||||
select a from t2 where b is null order by a desc,a,a;
|
||||
a
|
||||
3
|
||||
2
|
||||
1
|
||||
drop table t1, t2;
|
||||
set optimizer_switch=@save_optimizer_switch;
|
||||
set optimizer_switch=@save_ext_key_optimizer_switch;
|
||||
SET SESSION STORAGE_ENGINE=DEFAULT;
|
||||
|
@ -910,5 +910,30 @@ OR a = c
|
||||
ORDER BY e;
|
||||
a b c d e
|
||||
DROP TABLE t1,t2,t3;
|
||||
#
|
||||
# MDEV-5337: Wrong result in mariadb 5.5.32 with ORDER BY + LIMIT when index_condition_pushdown=on
|
||||
# MDEV-5512: Wrong result (WHERE clause ignored) with multiple clauses using Percona-XtraDB engine
|
||||
#
|
||||
create table t1(a int);
|
||||
insert into t1 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
|
||||
create table t2 (pk int primary key,
|
||||
key1 char(32),
|
||||
key2 char(32),
|
||||
key(key1),
|
||||
key(key2)
|
||||
) engine=innodb;
|
||||
insert into t2 select
|
||||
A.a+10*B.a+100*C.a,
|
||||
concat('rare-', A.a+10*B.a),
|
||||
concat('rare-', A.a+10*B.a)
|
||||
from
|
||||
t1 A, t1 B, t1 C;
|
||||
update t2 set key1='frequent-val' where pk between 100 and 350;
|
||||
select * from t2 ignore key(PRIMARY)
|
||||
where key1='frequent-val' and key2 between 'rare-400' and 'rare-450' order by pk limit 2;
|
||||
pk key1 key2
|
||||
141 frequent-val rare-41
|
||||
142 frequent-val rare-42
|
||||
drop table t1, t2;
|
||||
set optimizer_switch=@innodb_icp_tmp;
|
||||
set storage_engine= @save_storage_engine;
|
||||
|
@ -697,3 +697,23 @@ ERROR 42000: Column 'a' specified twice
|
||||
INSERT IGNORE t1 (a, a) SELECT 1,1 UNION SELECT 2,2;
|
||||
ERROR 42000: Column 'a' specified twice
|
||||
DROP TABLE t1;
|
||||
#
|
||||
# MDEV-5168: Ensure that we can disable duplicate key warnings
|
||||
# from INSERT IGNORE
|
||||
#
|
||||
create table t1 (f1 int unique, f2 int unique);
|
||||
insert into t1 values (1,12);
|
||||
insert into t1 values (2,13);
|
||||
insert into t1 values (1,12);
|
||||
ERROR 23000: Duplicate entry '1' for key 'f1'
|
||||
insert ignore into t1 values (1,12);
|
||||
Warnings:
|
||||
Warning 1062 Duplicate entry '1' for key 'f1'
|
||||
set @@old_mode="NO_DUP_KEY_WARNINGS_WITH_IGNORE";
|
||||
insert ignore into t1 values (1,12);
|
||||
insert ignore into t1 values (1,12) on duplicate key update f2=13;
|
||||
set @@old_mode="";
|
||||
insert ignore into t1 values (1,12);
|
||||
Warnings:
|
||||
Warning 1062 Duplicate entry '1' for key 'f1'
|
||||
DROP TABLE t1;
|
||||
|
@ -21,3 +21,4 @@ a left(b,10)
|
||||
3 CCCCCCCCCC
|
||||
4 CCCCCCCCCC
|
||||
drop table t1;
|
||||
set debug_sync='reset';
|
||||
|
@ -1,6 +1,7 @@
|
||||
#
|
||||
# MDEV-5226 mysql_tzinfo_to_sql errors with tzdata 2013f and above
|
||||
#
|
||||
# Verbose run
|
||||
TRUNCATE TABLE time_zone;
|
||||
TRUNCATE TABLE time_zone_name;
|
||||
TRUNCATE TABLE time_zone_transition;
|
||||
@ -11,12 +12,51 @@ INSERT INTO time_zone_name (Name, Time_zone_id) VALUES ('GMT', @time_zone_id);
|
||||
INSERT INTO time_zone_transition_type (Time_zone_id, Transition_type_id, Offset, Is_DST, Abbreviation) VALUES
|
||||
(@time_zone_id, 0, 0, 0, 'GMT')
|
||||
;
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/garbage' as time zone. Skipping it.
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/ignored.tab' as time zone. Skipping it.
|
||||
INSERT INTO time_zone (Use_leap_seconds) VALUES ('N');
|
||||
SET @time_zone_id= LAST_INSERT_ID();
|
||||
INSERT INTO time_zone_name (Name, Time_zone_id) VALUES ('posix/GMT', @time_zone_id);
|
||||
INSERT INTO time_zone_transition_type (Time_zone_id, Transition_type_id, Offset, Is_DST, Abbreviation) VALUES
|
||||
(@time_zone_id, 0, 0, 0, 'GMT')
|
||||
;
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/posix/garbage' as time zone. Skipping it.
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/posix/ignored.tab' as time zone. Skipping it.
|
||||
Warning: Skipping directory 'MYSQLTEST_VARDIR/zoneinfo/posix/posix': to avoid infinite symlink recursion.
|
||||
ALTER TABLE time_zone_transition ORDER BY Time_zone_id, Transition_time;
|
||||
ALTER TABLE time_zone_transition_type ORDER BY Time_zone_id, Transition_type_id;
|
||||
# Silent run
|
||||
TRUNCATE TABLE time_zone;
|
||||
TRUNCATE TABLE time_zone_name;
|
||||
TRUNCATE TABLE time_zone_transition;
|
||||
TRUNCATE TABLE time_zone_transition_type;
|
||||
INSERT INTO time_zone (Use_leap_seconds) VALUES ('N');
|
||||
SET @time_zone_id= LAST_INSERT_ID();
|
||||
INSERT INTO time_zone_name (Name, Time_zone_id) VALUES ('GMT', @time_zone_id);
|
||||
INSERT INTO time_zone_transition_type (Time_zone_id, Transition_type_id, Offset, Is_DST, Abbreviation) VALUES
|
||||
(@time_zone_id, 0, 0, 0, 'GMT')
|
||||
;
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/garbage' as time zone. Skipping it.
|
||||
INSERT INTO time_zone (Use_leap_seconds) VALUES ('N');
|
||||
SET @time_zone_id= LAST_INSERT_ID();
|
||||
INSERT INTO time_zone_name (Name, Time_zone_id) VALUES ('posix/GMT', @time_zone_id);
|
||||
INSERT INTO time_zone_transition_type (Time_zone_id, Transition_type_id, Offset, Is_DST, Abbreviation) VALUES
|
||||
(@time_zone_id, 0, 0, 0, 'GMT')
|
||||
;
|
||||
Warning: Unable to load 'MYSQLTEST_VARDIR/zoneinfo/posix/garbage' as time zone. Skipping it.
|
||||
ALTER TABLE time_zone_transition ORDER BY Time_zone_id, Transition_time;
|
||||
ALTER TABLE time_zone_transition_type ORDER BY Time_zone_id, Transition_type_id;
|
||||
#
|
||||
# Testing with explicit timezonefile
|
||||
#
|
||||
INSERT INTO time_zone (Use_leap_seconds) VALUES ('N');
|
||||
SET @time_zone_id= LAST_INSERT_ID();
|
||||
INSERT INTO time_zone_name (Name, Time_zone_id) VALUES ('XXX', @time_zone_id);
|
||||
INSERT INTO time_zone_transition_type (Time_zone_id, Transition_type_id, Offset, Is_DST, Abbreviation) VALUES
|
||||
(@time_zone_id, 0, 0, 0, 'GMT')
|
||||
;
|
||||
#
|
||||
# Testing --leap
|
||||
#
|
||||
TRUNCATE TABLE time_zone_leap_second;
|
||||
ALTER TABLE time_zone_leap_second ORDER BY Transition_time;
|
||||
|
@ -126,6 +126,9 @@ test
|
||||
Phase 3/3: Running 'mysql_fix_privilege_tables'...
|
||||
OK
|
||||
DROP USER mysqltest1@'%';
|
||||
Version check failed. Got the following error when calling the 'mysql' command line client
|
||||
ERROR 1045 (28000): Access denied for user 'mysqltest1'@'localhost' (using password: YES)
|
||||
FATAL ERROR: Upgrade failed
|
||||
Run mysql_upgrade with a non existing server socket
|
||||
mysqlcheck: Got error: 2005: Unknown MySQL server host 'not_existing_host' (errno) when trying to connect
|
||||
FATAL ERROR: Upgrade failed
|
||||
|
@ -468,8 +468,12 @@ The following options may be given as the first argument:
|
||||
--net-write-timeout=#
|
||||
Number of seconds to wait for a block to be written to a
|
||||
connection before aborting the write
|
||||
--old Use compatible behavior
|
||||
--old Use compatible behavior from previous MariaDB version.
|
||||
See also --old-mode
|
||||
--old-alter-table Use old, non-optimized alter table
|
||||
--old-mode=name Used to emulate old behavior from earlier MariaDB or
|
||||
MySQL versions. Syntax: old_mode=mode[,mode[,mode...]].
|
||||
See the manual for the complete list of valid old modes
|
||||
--old-passwords Use old password encryption method (needed for 4.0 and
|
||||
older clients)
|
||||
--old-style-user-limits
|
||||
@ -1164,6 +1168,7 @@ net-retry-count 10
|
||||
net-write-timeout 60
|
||||
old FALSE
|
||||
old-alter-table FALSE
|
||||
old-mode
|
||||
old-passwords FALSE
|
||||
old-style-user-limits FALSE
|
||||
optimizer-prune-level 1
|
||||
|
@ -357,6 +357,12 @@ id select_type table type possible_keys key key_len ref rows Extra
|
||||
explain select * from t1 where a = 1 order by b desc;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ref a a 4 const 5 Using where; Using index
|
||||
explain select * from t1 where a = 2 and b > 0 order by a desc,b desc,b,a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 range a a 9 NULL 5 Using where; Using index
|
||||
explain select * from t1 where a = 2 and b < 2 order by a desc,a,b desc,a,b;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 range a a 9 NULL 2 Using where; Using index
|
||||
select * from t1 where a = 1 order by b desc;
|
||||
a b c
|
||||
1 3 b
|
||||
@ -2905,4 +2911,28 @@ id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 index NULL PRIMARY 4 NULL 8 Using index
|
||||
1 SIMPLE t2 ref i_a i_a 5 test.t1.a 2 Using index
|
||||
DROP TABLE t1,t2;
|
||||
#
|
||||
# MDEV-4974 memory leak in 5.5.32-MariaDB-1~wheezy-log
|
||||
#
|
||||
set sort_buffer_size=default;
|
||||
set max_sort_length=default;
|
||||
create table t1(a int);
|
||||
insert into t1 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
|
||||
create table t2 (b int,
|
||||
col1 varchar(255),
|
||||
col2 varchar(255)
|
||||
) character set utf8;
|
||||
insert into t2 select
|
||||
A.a+10*B.a,
|
||||
concat('wow-wow-col1-value-', A.a+10*B.a+100*C.a),
|
||||
concat('wow-wow-col2-value-', A.a+10*B.a+100*C.a)
|
||||
from
|
||||
t1 A, t1 B, t1 C where C.a < 8;
|
||||
create table t3 as
|
||||
select distinct A.col1 as XX, B.col1 as YY
|
||||
from
|
||||
t2 A, t2 B
|
||||
where A.b = B.b
|
||||
order by A.col2, B.col2 limit 10, 1000000;
|
||||
drop table t1,t2,t3;
|
||||
End of 5.5 tests
|
||||
|
@ -1,6 +1,6 @@
|
||||
Illegal error code: 10000
|
||||
MySQL error code 1062 (ER_DUP_ENTRY): Duplicate entry '%-.192s' for key %d
|
||||
MySQL error code 1076 (ER_READY): %s: ready for connections.
|
||||
Version: '%s' socket: '%s' port: %d
|
||||
MySQL error code 1408 (ER_STARTUP): %s: ready for connections.
|
||||
Version: '%s' socket: '%s' port: %d %s
|
||||
MySQL error code 1459 (ER_TABLE_NEEDS_UPGRADE): Table upgrade required. Please do "REPAIR TABLE `%-.32s`" or dump/reload to fix it!
|
||||
MySQL error code 1461 (ER_MAX_PREPARED_STMT_COUNT_REACHED): Can't create more than max_prepared_stmt_count statements (current value: %lu)
|
||||
|
@ -300,7 +300,6 @@ FLUSH PRIVILEGES;
|
||||
mysqld is alive
|
||||
# Executing 'mysqldump'
|
||||
# Executing 'mysql_upgrade'
|
||||
The --upgrade-system-tables option was used, databases won't be touched.
|
||||
#
|
||||
# Bug #59657: Move the client authentication_pam plugin into the
|
||||
# server repository
|
||||
|
22
mysql-test/r/plugin_vars.result
Normal file
22
mysql-test/r/plugin_vars.result
Normal file
@ -0,0 +1,22 @@
|
||||
#
|
||||
# MDEV-5345 - Deadlock between mysql_change_user(), SHOW VARIABLES and
|
||||
# INSTALL PLUGIN
|
||||
#
|
||||
CREATE PROCEDURE p_install(x INT)
|
||||
BEGIN
|
||||
DECLARE CONTINUE HANDLER FOR 1126 BEGIN END;
|
||||
WHILE x DO
|
||||
SET x= x - 1;
|
||||
INSTALL PLUGIN no_such_plugin SONAME 'no_such_object';
|
||||
END WHILE;
|
||||
END|
|
||||
CREATE PROCEDURE p_show_vars(x INT)
|
||||
WHILE x DO
|
||||
SET x= x - 1;
|
||||
SHOW VARIABLES;
|
||||
END WHILE|
|
||||
CALL p_install(100);
|
||||
CALL p_show_vars(100);
|
||||
USE test;
|
||||
DROP PROCEDURE p_install;
|
||||
DROP PROCEDURE p_show_vars;
|
@ -13,3 +13,4 @@ sleep(5)
|
||||
select command, time < 5 from information_schema.processlist where id != connection_id();
|
||||
command time < 5
|
||||
Sleep 1
|
||||
set debug_sync='reset';
|
||||
|
@ -29,3 +29,4 @@ kill %connection%;
|
||||
set debug_sync='now signal done';
|
||||
Got one of the listed errors
|
||||
drop table t1;
|
||||
set debug_sync='reset';
|
||||
|
@ -2046,3 +2046,34 @@ f1 f2 f3 f4
|
||||
10 0 0 0
|
||||
DROP TABLE t1;
|
||||
DROP VIEW v3;
|
||||
#
|
||||
# MDEV-5606: range optimizer: "x < y" is sargable, while "y > x" is not
|
||||
#
|
||||
create table t1(a int);
|
||||
insert into t1 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
|
||||
create table t2(a int);
|
||||
insert into t2 select A.a + B.a* 10 + C.a * 100 from t1 A, t1 B, t1 C;
|
||||
alter table t2 add key(a);
|
||||
# Should have "range checked for each table" for second table:
|
||||
explain select * from t1, t2 where t2.a < t1.a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 10
|
||||
1 SIMPLE t2 ALL a NULL NULL NULL 1000 Range checked for each record (index map: 0x1)
|
||||
# Should have "range checked for each table" for second table:
|
||||
explain select * from t1, t2 where t1.a > t2.a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 10
|
||||
1 SIMPLE t2 ALL a NULL NULL NULL 1000 Range checked for each record (index map: 0x1)
|
||||
create table t3 (a int primary key, b int);
|
||||
insert into t3 select a,a from t1;
|
||||
# The second table should use 'range':
|
||||
explain select * from t3, t2 where t2.a < t3.b and t3.a=1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t3 const PRIMARY PRIMARY 4 const 1
|
||||
1 SIMPLE t2 range a a 5 NULL 1 Using where; Using index
|
||||
# The second table should use 'range':
|
||||
explain select * from t3, t2 where t3.b > t2.a and t3.a=1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t3 const PRIMARY PRIMARY 4 const 1
|
||||
1 SIMPLE t2 range a a 5 NULL 1 Using where; Using index
|
||||
drop table t1,t2,t3;
|
||||
|
@ -2048,4 +2048,35 @@ f1 f2 f3 f4
|
||||
10 0 0 0
|
||||
DROP TABLE t1;
|
||||
DROP VIEW v3;
|
||||
#
|
||||
# MDEV-5606: range optimizer: "x < y" is sargable, while "y > x" is not
|
||||
#
|
||||
create table t1(a int);
|
||||
insert into t1 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
|
||||
create table t2(a int);
|
||||
insert into t2 select A.a + B.a* 10 + C.a * 100 from t1 A, t1 B, t1 C;
|
||||
alter table t2 add key(a);
|
||||
# Should have "range checked for each table" for second table:
|
||||
explain select * from t1, t2 where t2.a < t1.a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 10
|
||||
1 SIMPLE t2 ALL a NULL NULL NULL 1000 Range checked for each record (index map: 0x1)
|
||||
# Should have "range checked for each table" for second table:
|
||||
explain select * from t1, t2 where t1.a > t2.a;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t1 ALL NULL NULL NULL NULL 10
|
||||
1 SIMPLE t2 ALL a NULL NULL NULL 1000 Range checked for each record (index map: 0x1)
|
||||
create table t3 (a int primary key, b int);
|
||||
insert into t3 select a,a from t1;
|
||||
# The second table should use 'range':
|
||||
explain select * from t3, t2 where t2.a < t3.b and t3.a=1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t3 const PRIMARY PRIMARY 4 const 1
|
||||
1 SIMPLE t2 range a a 5 NULL 1 Using where; Using index
|
||||
# The second table should use 'range':
|
||||
explain select * from t3, t2 where t3.b > t2.a and t3.a=1;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t3 const PRIMARY PRIMARY 4 const 1
|
||||
1 SIMPLE t2 range a a 5 NULL 1 Using where; Using index
|
||||
drop table t1,t2,t3;
|
||||
set optimizer_switch=@mrr_icp_extra_tmp;
|
||||
|
@ -130,26 +130,25 @@ test.t1 check error Table upgrade required. Please do "REPAIR TABLE `t1`" or dum
|
||||
# REPAIR old table USE_FRM should fail
|
||||
REPAIR TABLE t1 USE_FRM;
|
||||
Table Op Msg_type Msg_text
|
||||
t1 repair error Failed repairing incompatible .frm file
|
||||
test.t1 repair warning Number of rows changed from 0 to 1
|
||||
test.t1 repair status OK
|
||||
# Run REPAIR TABLE to upgrade .frm file
|
||||
REPAIR TABLE t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 repair status OK
|
||||
SHOW TABLE STATUS LIKE 't1';
|
||||
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
|
||||
t1 MyISAM 10 Fixed 2 7 14 1970324836974591 1024 0 NULL # # NULL latin1_swedish_ci NULL
|
||||
t1 MyISAM 10 Fixed 1 7 7 1970324836974591 1024 0 NULL # # NULL latin1_swedish_ci NULL
|
||||
SELECT * FROM t1;
|
||||
id
|
||||
1
|
||||
2
|
||||
REPAIR TABLE t1 USE_FRM;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 repair warning Number of rows changed from 0 to 2
|
||||
test.t1 repair warning Number of rows changed from 0 to 1
|
||||
test.t1 repair status OK
|
||||
SELECT * FROM t1;
|
||||
id
|
||||
1
|
||||
2
|
||||
DROP TABLE t1;
|
||||
DROP TABLE IF EXISTS tt1;
|
||||
CREATE TEMPORARY TABLE tt1 (c1 INT);
|
||||
@ -183,3 +182,28 @@ test.t1 repair status OK
|
||||
test.t2 repair status OK
|
||||
set @@autocommit= default;
|
||||
drop tables t1, t2;
|
||||
#
|
||||
# Check that we have decent error messages when using crashed
|
||||
# .frm file from MySQL 3.23
|
||||
#
|
||||
# Test with a saved table from 3.23
|
||||
select count(*) from t1;
|
||||
ERROR HY000: Got error 190 "Incompatible key or row definition between the MariaDB .frm file and the information in the storage engine. You have to dump an" from storage engine MyISAM
|
||||
check table t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 check Error Got error 190 "Incompatible key or row definition between the MariaDB .frm file and the information in the storage engine. You have to dump an" from storage engine MyISAM
|
||||
test.t1 check error Corrupt
|
||||
repair table t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 repair Error Got error 190 "Incompatible key or row definition between the MariaDB .frm file and the information in the storage engine. You have to dump an" from storage engine MyISAM
|
||||
test.t1 repair error Corrupt
|
||||
repair table t1 use_frm;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 repair status OK
|
||||
select count(*) from t1;
|
||||
count(*)
|
||||
0
|
||||
check table t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 check status OK
|
||||
drop table t1;
|
||||
|
14
mysql-test/r/repair_symlink-5543.result
Normal file
14
mysql-test/r/repair_symlink-5543.result
Normal file
@ -0,0 +1,14 @@
|
||||
create table t1 (a int) engine=myisam data directory='MYSQL_TMP_DIR';
|
||||
insert t1 values (1);
|
||||
repair table t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t1 repair error Can't create new tempfile: 'MYSQL_TMP_DIR/t1.TMD'
|
||||
test.t1 repair status Operation failed
|
||||
drop table t1;
|
||||
create table t2 (a int) engine=aria data directory='MYSQL_TMP_DIR';
|
||||
insert t2 values (1);
|
||||
repair table t2;
|
||||
Table Op Msg_type Msg_text
|
||||
test.t2 repair error Can't create new tempfile: 'MYSQL_TMP_DIR/t2.TMD'
|
||||
test.t2 repair status Operation failed
|
||||
drop table t2;
|
@ -280,3 +280,14 @@ SELECT FOUND_ROWS();
|
||||
FOUND_ROWS()
|
||||
1
|
||||
DROP TABLE t1;
|
||||
create table t1 (f1 int primary key, f2 tinyint) engine=myisam;
|
||||
insert t1 values (10,3),(11,2),(12,3);
|
||||
create table t2 (f3 int primary key) engine=myisam;
|
||||
insert t2 values (11),(12),(13);
|
||||
select f1 from t1,t2 where f1=f3 and f2=3 order by f1;
|
||||
f1
|
||||
12
|
||||
select found_rows();
|
||||
found_rows()
|
||||
1
|
||||
drop table t1, t2;
|
||||
|
@ -1035,7 +1035,7 @@ INSERT INTO t3 VALUES
|
||||
explain
|
||||
SELECT b AS field1, b AS field2 FROM t1, t2, t3 WHERE d = b ORDER BY field1, field2;
|
||||
id select_type table type possible_keys key key_len ref rows Extra
|
||||
1 SIMPLE t2 system NULL NULL NULL NULL 1 Using filesort
|
||||
1 SIMPLE t2 system NULL NULL NULL NULL 1
|
||||
1 SIMPLE t1 index b b 6 NULL 107 Using where; Using index
|
||||
1 SIMPLE t3 ref PRIMARY PRIMARY 5 test.t1.b 1 Using index
|
||||
set @show_explain_probe_select_id=1;
|
||||
|
@ -229,3 +229,49 @@ testf_bug11763507
|
||||
DROP PROCEDURE testp_bug11763507;
|
||||
DROP FUNCTION testf_bug11763507;
|
||||
#END OF BUG#11763507 test.
|
||||
#
|
||||
# MDEV-5531 double call procedure in one session
|
||||
#
|
||||
CREATE TABLE `t1` (
|
||||
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
||||
`create_ts` int(10) unsigned DEFAULT '0',
|
||||
PRIMARY KEY (`id`)
|
||||
) ENGINE=MyISAM AUTO_INCREMENT=0 DEFAULT CHARSET=utf8;
|
||||
CREATE PROCEDURE test_5531 (IN step TINYINT(1))
|
||||
BEGIN
|
||||
DECLARE counts INT DEFAULT 0;
|
||||
DECLARE cur1 CURSOR FOR
|
||||
SELECT ct.id
|
||||
FROM (SELECT NULL) AS z
|
||||
JOIN (
|
||||
SELECT id
|
||||
FROM `t1`
|
||||
LIMIT 10
|
||||
) AS ct
|
||||
JOIN (SELECT NULL) AS x ON(
|
||||
EXISTS(
|
||||
SELECT 1
|
||||
FROM `t1`
|
||||
WHERE id=ct.id
|
||||
LIMIT 1
|
||||
)
|
||||
);
|
||||
IF step=1 THEN
|
||||
TRUNCATE t1;
|
||||
REPEAT
|
||||
INSERT INTO `t1`
|
||||
(create_ts) VALUES
|
||||
(UNIX_TIMESTAMP());
|
||||
SET counts=counts+1;
|
||||
UNTIL counts>150 END REPEAT;
|
||||
SET max_sp_recursion_depth=1;
|
||||
CALL test_5531(2);
|
||||
SET max_sp_recursion_depth=2;
|
||||
CALL test_5531(2);
|
||||
ELSEIF step=2 THEN
|
||||
OPEN cur1; CLOSE cur1;
|
||||
END IF;
|
||||
END $$
|
||||
CALL test_5531(1);
|
||||
DROP PROCEDURE test_5531;
|
||||
DROP TABLE t1;
|
||||
|
@ -2037,6 +2037,24 @@ INSERT INTO t1 VALUES (1,3,5),(2,4,6);
|
||||
SELECT * FROM t1 WHERE 8 IN (SELECT MIN(pk) FROM t1) AND (pk = a OR pk = b);
|
||||
pk a b
|
||||
DROP TABLE t1;
|
||||
#
|
||||
# MDEV-5368: Server crashes in Item_in_subselect::optimize on 2nd
|
||||
# execution of PS with IN subqueries, materialization+semijoin
|
||||
#
|
||||
CREATE TABLE t1 (a INT) ENGINE=MyISAM;
|
||||
INSERT INTO t1 VALUES (1),(3);
|
||||
CREATE TABLE t2 (b INT) ENGINE=MyISAM;
|
||||
CREATE ALGORITHM=MERGE VIEW v2 AS SELECT * FROM t2;
|
||||
INSERT INTO t2 VALUES (8),(9);
|
||||
PREPARE stmt FROM "
|
||||
SELECT * FROM t1 WHERE 1 IN ( SELECT b FROM v2 WHERE 2 IN ( SELECT MAX(a) FROM t1 ) )
|
||||
";
|
||||
EXECUTE stmt;
|
||||
a
|
||||
EXECUTE stmt;
|
||||
a
|
||||
DROP TABLE t1, t2;
|
||||
DROP VIEW v2;
|
||||
# End of 5.3 tests
|
||||
#
|
||||
# MDEV-5056: Wrong result (extra rows) with materialization+semijoin, IN subqueries
|
||||
@ -2058,6 +2076,24 @@ CA ML CA ML
|
||||
CA ML RO ML
|
||||
DROP TABLE t1,t2;
|
||||
set join_cache_level=@tmp_mdev5056;
|
||||
#
|
||||
# MDEV-5368: Server crashes in Item_in_subselect::optimize on 2nd
|
||||
# execution of PS with IN subqueries, materialization+semijoin
|
||||
#
|
||||
CREATE TABLE t1 (a INT) ENGINE=MyISAM;
|
||||
INSERT INTO t1 VALUES (1),(3);
|
||||
CREATE TABLE t2 (b INT) ENGINE=MyISAM;
|
||||
CREATE ALGORITHM=MERGE VIEW v2 AS SELECT * FROM t2;
|
||||
INSERT INTO t2 VALUES (8),(9);
|
||||
PREPARE stmt FROM "
|
||||
SELECT * FROM t1 WHERE 1 IN ( SELECT b FROM v2 WHERE 2 IN ( SELECT MAX(a) FROM t1 ) )
|
||||
";
|
||||
EXECUTE stmt;
|
||||
a
|
||||
EXECUTE stmt;
|
||||
a
|
||||
DROP TABLE t1, t2;
|
||||
DROP VIEW v2;
|
||||
# End of 5.5 tests
|
||||
set @subselect_mat_test_optimizer_switch_value=null;
|
||||
set @@optimizer_switch='materialization=on,in_to_exists=off,semijoin=off';
|
||||
|
@ -2931,10 +2931,10 @@ CREATE TABLE t3 (c3 VARCHAR(1)) ENGINE=MyISAM;
|
||||
INSERT INTO t3 VALUES ('x'),('d');
|
||||
SELECT * FROM t1, t2 WHERE pk IN ( SELECT pk FROM t1 LEFT JOIN t3 ON (c1 = c3 ) ) ORDER BY c2, c1;
|
||||
pk c1 c2
|
||||
4 NULL x
|
||||
3 c x
|
||||
1 v x
|
||||
2 v x
|
||||
3 c x
|
||||
4 NULL x
|
||||
5 x x
|
||||
# This should show that "t1 left join t3" is still in the semi-join nest:
|
||||
EXPLAIN EXTENDED
|
||||
|
@ -2945,10 +2945,10 @@ CREATE TABLE t3 (c3 VARCHAR(1)) ENGINE=MyISAM;
|
||||
INSERT INTO t3 VALUES ('x'),('d');
|
||||
SELECT * FROM t1, t2 WHERE pk IN ( SELECT pk FROM t1 LEFT JOIN t3 ON (c1 = c3 ) ) ORDER BY c2, c1;
|
||||
pk c1 c2
|
||||
4 NULL x
|
||||
3 c x
|
||||
1 v x
|
||||
2 v x
|
||||
3 c x
|
||||
4 NULL x
|
||||
5 x x
|
||||
# This should show that "t1 left join t3" is still in the semi-join nest:
|
||||
EXPLAIN EXTENDED
|
||||
|
@ -2077,6 +2077,24 @@ INSERT INTO t1 VALUES (1,3,5),(2,4,6);
|
||||
SELECT * FROM t1 WHERE 8 IN (SELECT MIN(pk) FROM t1) AND (pk = a OR pk = b);
|
||||
pk a b
|
||||
DROP TABLE t1;
|
||||
#
|
||||
# MDEV-5368: Server crashes in Item_in_subselect::optimize on 2nd
|
||||
# execution of PS with IN subqueries, materialization+semijoin
|
||||
#
|
||||
CREATE TABLE t1 (a INT) ENGINE=MyISAM;
|
||||
INSERT INTO t1 VALUES (1),(3);
|
||||
CREATE TABLE t2 (b INT) ENGINE=MyISAM;
|
||||
CREATE ALGORITHM=MERGE VIEW v2 AS SELECT * FROM t2;
|
||||
INSERT INTO t2 VALUES (8),(9);
|
||||
PREPARE stmt FROM "
|
||||
SELECT * FROM t1 WHERE 1 IN ( SELECT b FROM v2 WHERE 2 IN ( SELECT MAX(a) FROM t1 ) )
|
||||
";
|
||||
EXECUTE stmt;
|
||||
a
|
||||
EXECUTE stmt;
|
||||
a
|
||||
DROP TABLE t1, t2;
|
||||
DROP VIEW v2;
|
||||
# End of 5.3 tests
|
||||
#
|
||||
# MDEV-5056: Wrong result (extra rows) with materialization+semijoin, IN subqueries
|
||||
@ -2098,4 +2116,22 @@ CA ML CA ML
|
||||
CA ML RO ML
|
||||
DROP TABLE t1,t2;
|
||||
set join_cache_level=@tmp_mdev5056;
|
||||
#
|
||||
# MDEV-5368: Server crashes in Item_in_subselect::optimize on 2nd
|
||||
# execution of PS with IN subqueries, materialization+semijoin
|
||||
#
|
||||
CREATE TABLE t1 (a INT) ENGINE=MyISAM;
|
||||
INSERT INTO t1 VALUES (1),(3);
|
||||
CREATE TABLE t2 (b INT) ENGINE=MyISAM;
|
||||
CREATE ALGORITHM=MERGE VIEW v2 AS SELECT * FROM t2;
|
||||
INSERT INTO t2 VALUES (8),(9);
|
||||
PREPARE stmt FROM "
|
||||
SELECT * FROM t1 WHERE 1 IN ( SELECT b FROM v2 WHERE 2 IN ( SELECT MAX(a) FROM t1 ) )
|
||||
";
|
||||
EXECUTE stmt;
|
||||
a
|
||||
EXECUTE stmt;
|
||||
a
|
||||
DROP TABLE t1, t2;
|
||||
DROP VIEW v2;
|
||||
# End of 5.5 tests
|
||||
|
@ -326,5 +326,11 @@ NULL
|
||||
Warnings:
|
||||
Warning 1292 Incorrect datetime value: '00:00:00'
|
||||
#
|
||||
# MDEV-5506 safe_mutex: Trying to lock unitialized mutex at safemalloc.c on server shutdown after SELECT with CONVERT_TZ
|
||||
#
|
||||
SELECT CONVERT_TZ('2001-10-08 00:00:00', MAKE_SET(0,'+01:00'), '+00:00' );
|
||||
CONVERT_TZ('2001-10-08 00:00:00', MAKE_SET(0,'+01:00'), '+00:00' )
|
||||
NULL
|
||||
#
|
||||
# End of 5.3 tests
|
||||
#
|
||||
|
@ -309,7 +309,7 @@ SELECT CONVERT_TZ(GREATEST(DATE('2021-00-00'),DATE('2022-00-00')),'+00:00','+7:5
|
||||
CONVERT_TZ(GREATEST(DATE('2021-00-00'),DATE('2022-00-00')),'+00:00','+7:5')
|
||||
NULL
|
||||
Warnings:
|
||||
Warning 1292 Incorrect datetime value: '2022-00-00 00:00:00'
|
||||
Warning 1292 Incorrect datetime value: '2022-00-00'
|
||||
#
|
||||
# MDEV-4804 Date comparing false result
|
||||
#
|
||||
|
@ -181,7 +181,7 @@ SELECT CONVERT_TZ(GREATEST(TIME('00:00:00'),TIME('00:00:00')),'+00:00','+7:5');
|
||||
CONVERT_TZ(GREATEST(TIME('00:00:00'),TIME('00:00:00')),'+00:00','+7:5')
|
||||
NULL
|
||||
Warnings:
|
||||
Warning 1292 Incorrect datetime value: '0000-00-00 00:00:00'
|
||||
Warning 1292 Incorrect datetime value: '00:00:00'
|
||||
#
|
||||
# MDEV-4652 Wrong result for CONCAT(GREATEST(TIME('00:00:01'),TIME('00:00:00')))
|
||||
#
|
||||
|
@ -4950,6 +4950,56 @@ i1 c1 i1 c1
|
||||
deallocate prepare stmt;
|
||||
drop view v1;
|
||||
drop table t1,t2;
|
||||
create table t1 (a int);
|
||||
insert into t1 values (1),(2);
|
||||
create view v1 (a,r) as select a,rand() from t1;
|
||||
create table t2 select a, r as r1, r as r2, r as r3 from v1;
|
||||
select a, r1 = r2, r2 = r3 from t2;
|
||||
a r1 = r2 r2 = r3
|
||||
1 1 1
|
||||
2 1 1
|
||||
drop view v1;
|
||||
drop table t1,t2;
|
||||
#
|
||||
# MDEV-5515: 2nd execution of a prepared statement returns wrong results
|
||||
#
|
||||
CREATE TABLE t1 (i1 INT, j1 INT NOT NULL, PRIMARY KEY (i1));
|
||||
INSERT INTO t1 VALUES (30,300),(40,400);
|
||||
CREATE TABLE t2 (i2 INT);
|
||||
INSERT INTO t2 VALUES (50),(60);
|
||||
CREATE TABLE t3 (c3 VARCHAR(20), i3 INT);
|
||||
INSERT INTO t3 VALUES ('a',10),('b',2);
|
||||
CREATE TABLE t4 (i4 INT);
|
||||
INSERT INTO t4 VALUES (1),(2);
|
||||
DROP VIEW IF EXISTS v1;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.v1'
|
||||
CREATE VIEW v1 AS select coalesce(j1,i3) AS v1_field1 from t2 join t3 left join t1 on ( i1 = i2 );
|
||||
CREATE VIEW v2 AS select v1_field1 from t4 join v1;
|
||||
prepare my_stmt from "select v1_field1 from v2";
|
||||
execute my_stmt;
|
||||
v1_field1
|
||||
10
|
||||
10
|
||||
10
|
||||
10
|
||||
2
|
||||
2
|
||||
2
|
||||
2
|
||||
execute my_stmt;
|
||||
v1_field1
|
||||
10
|
||||
10
|
||||
10
|
||||
10
|
||||
2
|
||||
2
|
||||
2
|
||||
2
|
||||
deallocate prepare my_stmt;
|
||||
DROP VIEW v1,v2;
|
||||
DROP TABLE t1,t2,t3,t4;
|
||||
# -----------------------------------------------------------------
|
||||
# -- End of 5.3 tests.
|
||||
# -----------------------------------------------------------------
|
||||
|
0
mysql-test/std_data/host_old.MYD
Normal file
0
mysql-test/std_data/host_old.MYD
Normal file
BIN
mysql-test/std_data/host_old.MYI
Normal file
BIN
mysql-test/std_data/host_old.MYI
Normal file
Binary file not shown.
BIN
mysql-test/std_data/host_old.frm
Normal file
BIN
mysql-test/std_data/host_old.frm
Normal file
Binary file not shown.
@ -5379,7 +5379,7 @@ ERROR 42000: The storage engine for the table doesn't support nullable columns
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Error 1178 The storage engine for the table doesn't support nullable columns
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 138 "Unsupported extension used for table")
|
||||
Warning 1112 Table 't1' uses an extension that doesn't exist in this MariaDB version
|
||||
create table t1 (c1 tinyblob not null) engine=csv;
|
||||
insert into t1 values("This");
|
||||
update t1 set c1="That" where c1="This";
|
||||
|
@ -6,7 +6,7 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Error 1 server name: 'non_existing' doesn't exist!
|
||||
Error 1 Can't create/write to file 'non_existing' (Errcode: 14 "Bad address")
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 1 "Operation not permitted")
|
||||
Warning 1030 Got error 1 "Operation not permitted" from storage engine FEDERATED
|
||||
create table t1 (a int);
|
||||
create table fed (a int) engine=Federated CONNECTION='mysql://root@127.0.0.1:MASTER_PORT/test/t1';
|
||||
drop table t1;
|
||||
|
@ -20,13 +20,13 @@ id name
|
||||
1 foo
|
||||
2 bar
|
||||
DELETE FROM federated.t1 WHERE id = 1;
|
||||
ERROR HY000: Got error 10000 'Error on remote system: 1031: Storage engine ARCHIVE of the table `federated`.`archive_table` doesn'' from FEDERATED
|
||||
ERROR HY000: Got error 10000 'Error on remote system: 1031: Storage engine ARCHIVE of the table `federated`.`archive_table` doesn't have this option' from FEDERATED
|
||||
SELECT * FROM federated.t1;
|
||||
id name
|
||||
1 foo
|
||||
2 bar
|
||||
UPDATE federated.t1 SET name='baz' WHERE id = 1;
|
||||
ERROR HY000: Got error 10000 'Error on remote system: 1031: Storage engine ARCHIVE of the table `federated`.`archive_table` doesn'' from FEDERATED
|
||||
ERROR HY000: Got error 10000 'Error on remote system: 1031: Storage engine ARCHIVE of the table `federated`.`archive_table` doesn't have this option' from FEDERATED
|
||||
SELECT * FROM federated.t1;
|
||||
id name
|
||||
1 foo
|
||||
|
@ -256,7 +256,7 @@ handler t1 read a=(1);
|
||||
a b
|
||||
handler t1 read a next;
|
||||
a b
|
||||
16 ccc
|
||||
14 aaa
|
||||
handler t1 close;
|
||||
handler t1 open;
|
||||
prepare stmt from 'handler t1 read a=(?) limit ?,?';
|
||||
@ -563,7 +563,7 @@ HANDLER t1 READ `primary` = (1, 1000);
|
||||
no1 no2
|
||||
HANDLER t1 READ `primary` NEXT;
|
||||
no1 no2
|
||||
2 8
|
||||
2 6
|
||||
DROP TABLE t1;
|
||||
create table t1 (c1 int);
|
||||
insert into t1 values (14397);
|
||||
|
@ -9,6 +9,11 @@
|
||||
# rename t/innodb_handler.test to t/handler_innodb.test
|
||||
#
|
||||
|
||||
if (`select plugin_auth_version < "5.6.15" from information_schema.plugins where plugin_name='innodb'`)
|
||||
{
|
||||
--skip Not fixed in InnoDB before 5.6.15
|
||||
}
|
||||
|
||||
--source include/have_innodb.inc
|
||||
|
||||
let $engine_type= InnoDB;
|
||||
|
126
mysql-test/suite/innodb/include/innodb-util.pl
Normal file
126
mysql-test/suite/innodb/include/innodb-util.pl
Normal file
@ -0,0 +1,126 @@
|
||||
#
|
||||
# Utility functions to copy files for WL#5522
|
||||
#
|
||||
# All the tables must be in the same database, you can call it like so:
|
||||
# ib_backup_tablespaces("test", "t1", "blah", ...).
|
||||
|
||||
use File::Copy;
|
||||
use File::Spec;
|
||||
|
||||
sub ib_normalize_path {
|
||||
my ($path) = @_;
|
||||
}
|
||||
|
||||
sub ib_backup_tablespace {
|
||||
my ($db, $table) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $cfg_file = sprintf("%s.cfg", $table);
|
||||
my $ibd_file = sprintf("%s.ibd", $table);
|
||||
my $tmpd = $ENV{'MYSQLTEST_VARDIR'} . "/tmp";
|
||||
|
||||
my @args = (File::Spec->catfile($datadir, $db, $ibd_file),
|
||||
File::Spec->catfile($tmpd, $ibd_file));
|
||||
|
||||
copy(@args) or die "copy @args failed: $!";
|
||||
|
||||
my @args = (File::Spec->catfile($datadir, $db, $cfg_file),
|
||||
File::Spec->catfile($tmpd, $cfg_file));
|
||||
|
||||
copy(@args) or die "copy @args failed: $!";
|
||||
}
|
||||
|
||||
sub ib_cleanup {
|
||||
my ($db, $table) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $cfg_file = sprintf("%s.cfg", $table);
|
||||
|
||||
print "unlink: $cfg_file\n";
|
||||
|
||||
# These may or may not exist
|
||||
unlink(File::Spec->catfile($datadir, $db, $cfg_file));
|
||||
}
|
||||
|
||||
sub ib_unlink_tablespace {
|
||||
my ($db, $table) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $ibd_file = sprintf("%s.ibd", $table);
|
||||
|
||||
print "unlink: $ibd_file\n";
|
||||
# This may or may not exist
|
||||
unlink(File::Spec->catfile($datadir, $db, $ibd_file));
|
||||
|
||||
ib_cleanup($db, $table);
|
||||
}
|
||||
|
||||
sub ib_backup_tablespaces {
|
||||
my ($db, @tables) = @_;
|
||||
|
||||
foreach my $table (@tables) {
|
||||
print "backup: $table\n";
|
||||
ib_backup_tablespace($db, $table);
|
||||
}
|
||||
}
|
||||
|
||||
sub ib_discard_tablespace { }
|
||||
|
||||
sub ib_discard_tablespaces { }
|
||||
|
||||
sub ib_restore_cfg_file {
|
||||
my ($tmpd, $datadir, $db, $table) = @_;
|
||||
my $cfg_file = sprintf("%s.cfg", $table);
|
||||
|
||||
my @args = (File::Spec->catfile($tmpd, $cfg_file),
|
||||
File::Spec->catfile($datadir, "$db", $cfg_file));
|
||||
|
||||
copy(@args) or die "copy @args failed: $!";
|
||||
}
|
||||
|
||||
sub ib_restore_ibd_file {
|
||||
my ($tmpd, $datadir, $db, $table) = @_;
|
||||
my $ibd_file = sprintf("%s.ibd", $table);
|
||||
|
||||
my @args = (File::Spec->catfile($tmpd, $ibd_file),
|
||||
File::Spec->catfile($datadir, $db, $ibd_file));
|
||||
|
||||
copy(@args) or die "copy @args failed: $!";
|
||||
}
|
||||
|
||||
sub ib_restore_tablespace {
|
||||
my ($db, $table) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $tmpd = $ENV{'MYSQLTEST_VARDIR'} . "/tmp";
|
||||
|
||||
ib_restore_cfg_file($tmpd, $datadir, $db, $table);
|
||||
ib_restore_ibd_file($tmpd, $datadir, $db, $table);
|
||||
}
|
||||
|
||||
sub ib_restore_tablespaces {
|
||||
my ($db, @tables) = @_;
|
||||
|
||||
foreach my $table (@tables) {
|
||||
print "restore: $table .ibd and .cfg files\n";
|
||||
ib_restore_tablespace($db, $table);
|
||||
}
|
||||
}
|
||||
|
||||
sub ib_restore_cfg_files {
|
||||
my ($db, @tables) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $tmpd = $ENV{'MYSQLTEST_VARDIR'} . "/tmp";
|
||||
|
||||
foreach my $table (@tables) {
|
||||
print "restore: $table .cfg file\n";
|
||||
ib_restore_cfg_file($tmpd, $datadir, $db, $table);
|
||||
}
|
||||
}
|
||||
|
||||
sub ib_restore_ibd_files {
|
||||
my ($db, @tables) = @_;
|
||||
my $datadir = $ENV{'MYSQLD_DATADIR'};
|
||||
my $tmpd = $ENV{'MYSQLTEST_VARDIR'} . "/tmp";
|
||||
|
||||
foreach my $table (@tables) {
|
||||
print "restore: $table .ibd file\n";
|
||||
ib_restore_ibd_file($tmpd, $datadir, $db, $table);
|
||||
}
|
||||
}
|
21
mysql-test/suite/innodb/r/innodb-alter-discard.result
Normal file
21
mysql-test/suite/innodb/r/innodb-alter-discard.result
Normal file
@ -0,0 +1,21 @@
|
||||
SET GLOBAL innodb_file_per_table=1;
|
||||
CREATE TABLE t(a INT)ENGINE=InnoDB;
|
||||
call mtr.add_suppression("InnoDB: Error: trying to open a table, but could not$");
|
||||
call mtr.add_suppression("MySQL is trying to open a table handle but the \.ibd file for$");
|
||||
call mtr.add_suppression("InnoDB: Table 'test/t'$");
|
||||
call mtr.add_suppression("Could not find a valid tablespace file for");
|
||||
call mtr.add_suppression("InnoDB: Tablespace open failed for '\"test\"\.\"t\"', ignored");
|
||||
call mtr.add_suppression("InnoDB: Failed to find tablespace for table '\"test\"\.\"t\"' in the cache");
|
||||
call mtr.add_suppression("InnoDB: Cannot delete tablespace [0-9]+.*not found");
|
||||
call mtr.add_suppression("Table .*t in the InnoDB data dictionary has tablespace id .*, but tablespace with that id or name does not exist");
|
||||
SELECT * FROM t;
|
||||
ERROR 42S02: Table 'test.t' doesn't exist in engine
|
||||
ALTER TABLE t ADD INDEX (a), ALGORITHM=INPLACE;
|
||||
ERROR 42S02: Table 'test.t' doesn't exist in engine
|
||||
ALTER TABLE t1 ADD INDEX (a), ALGORITHM=COPY;
|
||||
ERROR 42S02: Table 'test.t1' doesn't exist
|
||||
ALTER TABLE t DISCARD TABLESPACE;
|
||||
Warnings:
|
||||
Warning 1812 Tablespace is missing for table 'test/t'
|
||||
Warning 1812 Tablespace is missing for table 't'
|
||||
DROP TABLE t;
|
42
mysql-test/suite/innodb/r/innodb-bug-14068765.result
Normal file
42
mysql-test/suite/innodb/r/innodb-bug-14068765.result
Normal file
@ -0,0 +1,42 @@
|
||||
DROP TABLE IF EXISTS t1;
|
||||
SET GLOBAL innodb_file_per_table = 1;
|
||||
SELECT @@innodb_file_per_table;
|
||||
@@innodb_file_per_table
|
||||
1
|
||||
CREATE DATABASE testdb_wl5522;
|
||||
CREATE TABLE testdb_wl5522.t1(col1 bit(1) , col2 boolean,col3 tinyint , col4 smallint , col5 mediumint ,col6 int , col7 bigint , col8 float (14,3) ,col9 double (14,3), col10 VARCHAR(20) CHARACTER SET utf8 , col11 TEXT CHARACTER SET binary , col12 ENUM('a','b','c') CHARACTER SET binary ,col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,col14 CHAR(20) , col15 VARBINARY (400) , col16 BINARY(40), col17 BLOB (400) , col18 int not null primary key,col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,col22 TIME , col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1,1,-128,32767,-8388608,2147483647,-9223372036854775808, 92233720368.222,-92233720368.222,'aaa', 'aaaaaaaaaa','b','bbbbb','ccccc',REPEAT('d',40),REPEAT('d',40),REPEAT('d',40), 1,'1000-01-01','3000-12-31 23:59:59.99','1990-01-01 00:00:01.00','01:59:59.00','1901');
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,3,NULL,NULL,NULL,NULL,NULL);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Column 'col18' cannot be null
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
|
||||
FLUSH TABLES testdb_wl5522.t1 WITH READ LOCK;
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1(col1 bit(1) , col2 boolean,col3 tinyint , col4 smallint , col5 mediumint ,col6 int , col7 bigint , col8 float (14,3) ,col9 double (14,3), col10 VARCHAR(20) CHARACTER SET utf8 , col11 TEXT CHARACTER SET binary , col12 ENUM('a','b','c') CHARACTER SET binary ,col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,col14 CHAR(20) , col15 VARBINARY (400) , col16 BINARY(40), col17 BLOB (400) , col18 int not null primary key,col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,col22 TIME , col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
CHECK TABLE testdb_wl5522.t1;
|
||||
Table Op Msg_type Msg_text
|
||||
testdb_wl5522.t1 check status OK
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
DROP DATABASE testdb_wl5522;
|
||||
SET GLOBAL INNODB_FILE_FORMAT=Antelope;
|
||||
SET GLOBAL INNODB_FILE_PER_TABLE=1;
|
31
mysql-test/suite/innodb/r/innodb-bug-14084530.result
Normal file
31
mysql-test/suite/innodb/r/innodb-bug-14084530.result
Normal file
@ -0,0 +1,31 @@
|
||||
DROP TABLE IF EXISTS t1;
|
||||
SET GLOBAL innodb_file_per_table = 1;
|
||||
SELECT @@innodb_file_per_table;
|
||||
@@innodb_file_per_table
|
||||
1
|
||||
SET AUTOCOMMIT = 0;
|
||||
CREATE DATABASE testdb_wl5522;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 int ) engine = Innodb;
|
||||
BEGIN;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1),(123),(331);
|
||||
ROLLBACK;
|
||||
SELECT c1 FROM testdb_wl5522.t1;
|
||||
c1
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 int ) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
CHECK TABLE testdb_wl5522.t1;
|
||||
Table Op Msg_type Msg_text
|
||||
testdb_wl5522.t1 check status OK
|
||||
SELECT c1 FROM testdb_wl5522.t1;
|
||||
c1
|
||||
SET AUTOCOMMIT = 1;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
DROP DATABASE testdb_wl5522;
|
||||
SET GLOBAL INNODB_FILE_FORMAT=Antelope;
|
||||
SET GLOBAL INNODB_FILE_PER_TABLE=1;
|
@ -15,6 +15,7 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: invalid ROW_FORMAT specifier.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=0;
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
@ -63,18 +64,21 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: cannot specify ROW_FORMAT = COMPACT with KEY_BLOCK_SIZE.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=REDUNDANT KEY_BLOCK_SIZE=2;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: cannot specify ROW_FORMAT = REDUNDANT with KEY_BLOCK_SIZE.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=DYNAMIC KEY_BLOCK_SIZE=4;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: cannot specify ROW_FORMAT = DYNAMIC with KEY_BLOCK_SIZE.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=2;
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
@ -255,6 +259,7 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: invalid KEY_BLOCK_SIZE = 9. Valid values are [1, 2, 4, 8, 16]
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
# Test 7) StrictMode=ON, Make sure ROW_FORMAT= COMPRESSED & DYNAMIC and
|
||||
# and a valid non-zero KEY_BLOCK_SIZE are rejected with Antelope
|
||||
# and that they can be set to default values during strict mode.
|
||||
@ -268,18 +273,21 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: KEY_BLOCK_SIZE requires innodb_file_format > Antelope.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=COMPRESSED;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: ROW_FORMAT=COMPRESSED requires innodb_file_format > Antelope.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=DYNAMIC;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: ROW_FORMAT=DYNAMIC requires innodb_file_format > Antelope.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=REDUNDANT;
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
@ -352,18 +360,21 @@ SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: KEY_BLOCK_SIZE requires innodb_file_per_table.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=COMPRESSED;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: ROW_FORMAT=COMPRESSED requires innodb_file_per_table.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=DYNAMIC;
|
||||
ERROR HY000: Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
Warning 1478 InnoDB: ROW_FORMAT=DYNAMIC requires innodb_file_per_table.
|
||||
Error 1005 Can't create table `test`.`t1` (errno: 140 "Wrong create options")
|
||||
Warning 1030 Got error 140 "Wrong create options" from storage engine InnoDB
|
||||
CREATE TABLE t1 ( i INT ) ROW_FORMAT=REDUNDANT;
|
||||
SHOW WARNINGS;
|
||||
Level Code Message
|
||||
|
811
mysql-test/suite/innodb/r/innodb-wl5522-1.result
Normal file
811
mysql-test/suite/innodb/r/innodb-wl5522-1.result
Normal file
@ -0,0 +1,811 @@
|
||||
DROP TABLE IF EXISTS t1;
|
||||
SET GLOBAL innodb_file_per_table = 1;
|
||||
SELECT @@innodb_file_per_table;
|
||||
@@innodb_file_per_table
|
||||
1
|
||||
SET GLOBAL innodb_file_format = `Barracuda`;
|
||||
SELECT @@innodb_file_format;
|
||||
@@innodb_file_format
|
||||
Barracuda
|
||||
DROP DATABASE IF EXISTS testdb_wl5522;
|
||||
Warnings:
|
||||
Note 1008 Can't drop database 'testdb_wl5522'; database doesn't exist
|
||||
CREATE DATABASE testdb_wl5522;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 INT ) ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1),(123),(331);
|
||||
SELECT c1 FROM testdb_wl5522.t1;
|
||||
c1
|
||||
1
|
||||
123
|
||||
331
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY c1;
|
||||
c1
|
||||
1
|
||||
123
|
||||
331
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 INT ) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY c1;
|
||||
c1
|
||||
1
|
||||
123
|
||||
331
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col1 BIT(1),
|
||||
col2 BOOLEAN,
|
||||
col3 TINYINT,
|
||||
col4 SMALLINT,
|
||||
col5 MEDIUMINT,
|
||||
col6 INT,
|
||||
col7 BIGINT,
|
||||
col8 FLOAT (14,3) ,
|
||||
col9 DOUBLE (14,3),
|
||||
col10 VARCHAR(20),
|
||||
col11 TEXT ,
|
||||
col12 ENUM('a','b','c'),
|
||||
col13 TEXT,
|
||||
col14 CHAR(20) ,
|
||||
col15 VARBINARY (400) ,
|
||||
col16 BINARY(40),
|
||||
col17 BLOB (400) ,
|
||||
col18 INT NOT NULL PRIMARY KEY,
|
||||
col19 DATE ,
|
||||
col20 DATETIME ,
|
||||
col21 TIMESTAMP ,
|
||||
col22 TIME ,
|
||||
col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES
|
||||
(1,1,-128,32767,-8388608,2147483647,-9223372036854775808, 92233720368.222,
|
||||
-92233720368.222,'aaa', + 'aaaaaaaaaa','b','bbbbb','ccccc',
|
||||
REPEAT('d',40),REPEAT('d',40),REPEAT('d',40),1,'1000-01-01',
|
||||
'3000-12-31 23:59:59.99','1990-01-01 00:00:01.00',
|
||||
'01:59:59.00','1901');
|
||||
INSERT INTO testdb_wl5522.t1 VALUES
|
||||
(NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,3,NULL,NULL,NULL,NULL,NULL);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Column 'col18' cannot be null
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,1,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
|
||||
FLUSH TABLES testdb_wl5522.t1 WITH READ LOCK;
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col1 BIT(1),
|
||||
col2 BOOLEAN,
|
||||
col3 TINYINT,
|
||||
col4 SMALLINT,
|
||||
col5 MEDIUMINT,
|
||||
col6 INT,
|
||||
col7 BIGINT,
|
||||
col8 FLOAT (14,3) ,
|
||||
col9 DOUBLE (14,3),
|
||||
col10 VARCHAR(20),
|
||||
col11 TEXT,
|
||||
col12 ENUM('a','b','c'),
|
||||
col13 TEXT,
|
||||
col14 CHAR(20) ,
|
||||
col15 VARBINARY (400) ,
|
||||
col16 BINARY(40),
|
||||
col17 BLOB (400) ,
|
||||
col18 INT NOT NULL PRIMARY KEY,
|
||||
col19 DATE ,
|
||||
col20 DATETIME ,
|
||||
col21 TIMESTAMP ,
|
||||
col22 TIME ,
|
||||
col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
CHECK TABLE testdb_wl5522.t1;
|
||||
Table Op Msg_type Msg_text
|
||||
testdb_wl5522.t1 check status OK
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
SET GLOBAL innodb_file_format='Barracuda';
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_varbinary VARBINARY (4000) ,
|
||||
col_2_varchar VARCHAR (4000),
|
||||
col_3_text TEXT (4000),
|
||||
col_4_blob BLOB (4000),
|
||||
col_5_text TEXT (4000),
|
||||
col_6_varchar VARCHAR (4000),
|
||||
col_7_binary BINARY (255)
|
||||
) ROW_FORMAT=DYNAMIC ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES(
|
||||
REPEAT('a', 4000),REPEAT('o', 4000),REPEAT('a', 4000), REPEAT('o', 4000),
|
||||
REPEAT('a', 4000),REPEAT('a', 4000),REPEAT('a', 255));
|
||||
SELECT col_1_varbinary = REPEAT("a", 4000) ,
|
||||
col_2_varchar = REPEAT("o", 4000) ,
|
||||
col_3_text = REPEAT("a", 4000) ,
|
||||
col_4_blob = REPEAT("o", 4000) ,
|
||||
col_5_text = REPEAT("a", 4000) ,
|
||||
col_6_varchar = REPEAT("a", 4000) ,
|
||||
col_7_binary = REPEAT("a", 255)
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1_varbinary = REPEAT("a", 4000) col_2_varchar = REPEAT("o", 4000) col_3_text = REPEAT("a", 4000) col_4_blob = REPEAT("o", 4000) col_5_text = REPEAT("a", 4000) col_6_varchar = REPEAT("a", 4000) col_7_binary = REPEAT("a", 255)
|
||||
1 1 1 1 1 1 1
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_varbinary VARBINARY (4000) ,
|
||||
col_2_varchar VARCHAR (4000),
|
||||
col_3_text TEXT (4000),
|
||||
col_4_blob BLOB (4000),
|
||||
col_5_text TEXT (4000),
|
||||
col_6_varchar VARCHAR (4000),
|
||||
col_7_binary BINARY (255)
|
||||
) ROW_FORMAT=DYNAMIC ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT col_1_varbinary = REPEAT("a", 4000) ,
|
||||
col_2_varchar = REPEAT("o", 4000) ,
|
||||
col_3_text = REPEAT("a", 4000) ,
|
||||
col_4_blob = REPEAT("o", 4000) ,
|
||||
col_5_text = REPEAT("a", 4000) ,
|
||||
col_6_varchar = REPEAT("a", 4000) ,
|
||||
col_7_binary = REPEAT("a", 255)
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1_varbinary = REPEAT("a", 4000) col_2_varchar = REPEAT("o", 4000) col_3_text = REPEAT("a", 4000) col_4_blob = REPEAT("o", 4000) col_5_text = REPEAT("a", 4000) col_6_varchar = REPEAT("a", 4000) col_7_binary = REPEAT("a", 255)
|
||||
1 1 1 1 1 1 1
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int INT AUTO_INCREMENT,
|
||||
col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_1_int)) ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1,'a1'),(2,'a2'),(3,'a3');
|
||||
INSERT INTO testdb_wl5522.t1 (col_2_varchar) VALUES ('a4'),('a5'),('a6');
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
6 a6
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int INT AUTO_INCREMENT,
|
||||
col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_1_int)) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
6 a6
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1,'a1');
|
||||
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
|
||||
INSERT INTO testdb_wl5522.t1(col_2_varchar) VALUES ('a101'),('a102'),('a103');
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
6 a6
|
||||
7 a101
|
||||
8 a102
|
||||
9 a103
|
||||
ALTER TABLE testdb_wl5522.t1 MODIFY col_1_int BIGINT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
6 a6
|
||||
7 a101
|
||||
8 a102
|
||||
9 a103
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int INT,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_2_varchar)) ENGINE = Innodb;
|
||||
CREATE TABLE testdb_wl5522.t1_fk (
|
||||
col_1_int INT,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_1_int),
|
||||
FOREIGN KEY (col_2_varchar) REFERENCES testdb_wl5522.t1(col_2_varchar)
|
||||
) ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1,'a1'),(2,'a2'),(3,'a3'),(4,'a4'),(5,'a5');
|
||||
INSERT INTO testdb_wl5522.t1_fk VALUES (1,'a1'),(2,'a2'),(3,'a3');
|
||||
SELECT * FROM testdb_wl5522.t1;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
SELECT * FROM testdb_wl5522.t1_fk;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
FLUSH TABLES testdb_wl5522.t1,testdb_wl5522.t1_fk FOR EXPORT;
|
||||
backup: t1
|
||||
backup: t1_fk
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1_fk,testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int INT,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_2_varchar)) ENGINE = Innodb;
|
||||
CREATE TABLE testdb_wl5522.t1_fk (
|
||||
col_1_int INT,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_1_int),
|
||||
FOREIGN KEY (col_2_varchar) REFERENCES testdb_wl5522.t1(col_2_varchar)
|
||||
) ENGINE = Innodb;
|
||||
SET foreign_key_checks = 0;
|
||||
ALTER TABLE testdb_wl5522.t1_fk DISCARD TABLESPACE;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
SET foreign_key_checks = 1;
|
||||
restore: t1 .ibd and .cfg files
|
||||
restore: t1_fk .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
ALTER TABLE testdb_wl5522.t1_fk IMPORT TABLESPACE;
|
||||
SELECT * FROM testdb_wl5522.t1;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
4 a4
|
||||
5 a5
|
||||
SELECT * FROM testdb_wl5522.t1_fk;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
INSERT INTO testdb_wl5522.t1_fk VALUES (100,'a100');
|
||||
ERROR 23000: Cannot add or update a child row: a foreign key constraint fails (`testdb_wl5522`.`t1_fk`, CONSTRAINT `t1_fk_ibfk_1` FOREIGN KEY (`col_2_varchar`) REFERENCES `t1` (`col_2_varchar`))
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1_fk VALUES (4,'a4'),(5,'a5');
|
||||
ROLLBACK;
|
||||
SELECT * FROM testdb_wl5522.t1_fk;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
3 a3
|
||||
DROP TABLE testdb_wl5522.t1_fk,testdb_wl5522.t1;
|
||||
SET AUTOCOMMIT = 1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int int,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_2_varchar)) ENGINE = Innodb;
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1,'a1'),(2,'a2');
|
||||
SELECT * FROM testdb_wl5522.t1;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
COMMIT;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (3,'a3'),(4,'a4');
|
||||
ROLLBACK;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (5,'a5'),(6,'a6');
|
||||
COMMIT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
5 a5
|
||||
6 a6
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (
|
||||
col_1_int int,col_2_varchar VARCHAR (20),
|
||||
PRIMARY KEY (col_2_varchar)) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
SET AUTOCOMMIT = 0;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (7,'a7'),(8,'a8');
|
||||
COMMIT;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (9,'a9'),(10,'a10');
|
||||
ROLLBACK;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (11,'a11'),(12,'a12');
|
||||
COMMIT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY col_1_int;
|
||||
col_1_int col_2_varchar
|
||||
1 a1
|
||||
2 a2
|
||||
5 a5
|
||||
6 a6
|
||||
7 a7
|
||||
8 a8
|
||||
11 a11
|
||||
12 a12
|
||||
SET AUTOCOMMIT = 1;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 ( i int ) ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (100),(200),(300);
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 ( i int ) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (101),(102),(103);
|
||||
COMMIT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
101
|
||||
102
|
||||
103
|
||||
200
|
||||
300
|
||||
SET AUTOCOMMIT = 1;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 ( i int ) ENGINE = Innodb;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (100),(200),(300);
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 ( i bigint) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Schema mismatch (Column i precise type mismatch.)
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 ( i int ) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Tablespace for table 't1' exists. Please DISCARD the tablespace before IMPORT.
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
200
|
||||
300
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (101),(102),(103);
|
||||
COMMIT;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY i;
|
||||
i
|
||||
100
|
||||
101
|
||||
102
|
||||
103
|
||||
200
|
||||
300
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (i int) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
SET AUTOCOMMIT = 1;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 INT ) ENGINE = Innodb;
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (1),(123),(331);
|
||||
SELECT c1 FROM testdb_wl5522.t1;
|
||||
c1
|
||||
1
|
||||
123
|
||||
331
|
||||
ROLLBACK;
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (c1 INT ) ENGINE = Innodb;
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT * FROM testdb_wl5522.t1 ORDER BY c1;
|
||||
c1
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
SET AUTOCOMMIT = 1;
|
||||
CREATE TABLE testdb_wl5522.t1 (col_1 CHAR (255) ,
|
||||
col_2 VARCHAR (255), col_3 VARCHAR (255),
|
||||
col_4 VARCHAR (255),col_5 VARCHAR (255),
|
||||
col_6 text (255), col_7 text (255),
|
||||
col_8 text (255),col_9 text (255),
|
||||
col_10 BLOB (255),col_11 BLOB (255),
|
||||
col_12 BLOB (255), col_13 BLOB (255),
|
||||
col_14 BLOB (255) , col_15 int ) ENGINE = innodb;
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(
|
||||
col_1 (50),col_2 (50),col_3 (50),
|
||||
col_4 (50),col_5 (50),col_6 (50),
|
||||
col_7 (50),col_8 (50),col_9 (50),
|
||||
col_10 (50),col_11 (50),col_12 (50),
|
||||
col_13(50));
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
REPEAT("col1_00001",10),REPEAT("col2_00001",10),REPEAT("col3_00001",10),
|
||||
REPEAT("col4_00001",10),REPEAT("col5_00001",10),REPEAT("col6_00001",10),
|
||||
REPEAT("col7_00001",10),REPEAT("col8_00001",10),REPEAT("col9_00001",10),
|
||||
REPEAT("col10_00001",10),REPEAT("col11_00001",10),REPEAT("col12_00001",10),
|
||||
REPEAT("col13_00001",10),REPEAT("col14_00001",10),1);
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (col_1 CHAR (255) ,
|
||||
col_2 VARCHAR (255), col_3 VARCHAR (255),
|
||||
col_4 VARCHAR (255),col_5 VARCHAR (255),
|
||||
col_6 text (255), col_7 text (255),
|
||||
col_8 text (255),col_9 text (255),
|
||||
col_10 BLOB (255),col_11 BLOB (255),
|
||||
col_12 BLOB (255), col_13 BLOB (255),
|
||||
col_14 BLOB (255) , col_15 int ) ENGINE = innodb;
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(
|
||||
col_1 (50),col_2 (50),col_3 (50),
|
||||
col_4 (50),col_5 (50),col_6 (50),
|
||||
col_7 (50),col_8 (50),col_9 (50),
|
||||
col_10 (50),col_11 (50),col_12 (50),
|
||||
col_13(50));
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (col_1 CHAR (255) ,
|
||||
col_2 VARCHAR (255), col_3 VARCHAR (255),
|
||||
col_4 VARCHAR (255),col_5 VARCHAR (255),
|
||||
col_6 text (255), col_7 text (255),
|
||||
col_8 text (255),col_9 text (255),
|
||||
col_10 BLOB (255),col_11 BLOB (255),
|
||||
col_12 BLOB (255), col_13 BLOB (255),
|
||||
col_14 BLOB (255) , col_15 int ) ENGINE = innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col_1);
|
||||
CREATE INDEX idx2 ON testdb_wl5522.t1(col_2);
|
||||
CREATE INDEX idx3 ON testdb_wl5522.t1(col_3);
|
||||
CREATE INDEX idx4 ON testdb_wl5522.t1(col_4);
|
||||
CREATE INDEX idx5 ON testdb_wl5522.t1(col_5);
|
||||
CREATE INDEX idx6 ON testdb_wl5522.t1(col_6(255));
|
||||
CREATE INDEX idx7 ON testdb_wl5522.t1(col_7(255));
|
||||
CREATE INDEX idx8 ON testdb_wl5522.t1(col_8(255));
|
||||
CREATE INDEX idx9 ON testdb_wl5522.t1(col_9(255));
|
||||
CREATE INDEX idx10 ON testdb_wl5522.t1(col_10(255));
|
||||
CREATE INDEX idx11 ON testdb_wl5522.t1(col_11(255));
|
||||
CREATE INDEX idx12 ON testdb_wl5522.t1(col_12(255));
|
||||
CREATE INDEX idx13 ON testdb_wl5522.t1(col_13(255));
|
||||
CREATE INDEX idx14 ON testdb_wl5522.t1(col_14(255));
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
REPEAT("col1_00001",10),REPEAT("col2_00001",10),REPEAT("col3_00001",10),
|
||||
REPEAT("col4_00001",10),REPEAT("col5_00001",10),REPEAT("col6_00001",10),
|
||||
REPEAT("col7_00001",10),REPEAT("col8_00001",10),REPEAT("col9_00001",10),
|
||||
REPEAT("col10_00001",10),REPEAT("col11_00001",10),REPEAT("col12_00001",10),
|
||||
REPEAT("col13_00001",10),REPEAT("col14_00001",10),1);
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1 (col_1 CHAR (255) ,
|
||||
col_2 VARCHAR (255), col_3 VARCHAR (255),
|
||||
col_4 VARCHAR (255),col_5 VARCHAR (255),
|
||||
col_6 text (255), col_7 text (255),
|
||||
col_8 text (255),col_9 text (255),
|
||||
col_10 BLOB (255),col_11 BLOB (255),
|
||||
col_12 BLOB (255), col_13 BLOB (255),
|
||||
col_14 BLOB (255) , col_15 int ) ENGINE = innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col_1);
|
||||
CREATE INDEX idx2 ON testdb_wl5522.t1(col_2);
|
||||
CREATE INDEX idx3 ON testdb_wl5522.t1(col_3);
|
||||
CREATE INDEX idx4 ON testdb_wl5522.t1(col_4);
|
||||
CREATE INDEX idx5 ON testdb_wl5522.t1(col_5);
|
||||
CREATE INDEX idx6 ON testdb_wl5522.t1(col_6(255));
|
||||
CREATE INDEX idx7 ON testdb_wl5522.t1(col_7(255));
|
||||
CREATE INDEX idx8 ON testdb_wl5522.t1(col_8(255));
|
||||
CREATE INDEX idx9 ON testdb_wl5522.t1(col_9(255));
|
||||
CREATE INDEX idx10 ON testdb_wl5522.t1(col_10(255));
|
||||
CREATE INDEX idx11 ON testdb_wl5522.t1(col_11(255));
|
||||
CREATE INDEX idx12 ON testdb_wl5522.t1(col_12(255));
|
||||
CREATE INDEX idx13 ON testdb_wl5522.t1(col_13(255));
|
||||
CREATE INDEX idx14 ON testdb_wl5522.t1(col_14(255));
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
SET AUTOCOMMIT = 0;
|
||||
INSERT INTO testdb_wl5522.t1(col_15) VALUES (15000),(16000);
|
||||
SELECT col_15 FROM testdb_wl5522.t1 WHERE col_15 > 11000;
|
||||
col_15
|
||||
15000
|
||||
16000
|
||||
ROLLBACK;
|
||||
SELECT col_15 FROM testdb_wl5522.t1 WHERE col_15 > 11000;
|
||||
col_15
|
||||
INSERT INTO testdb_wl5522.t1(col_15) VALUES (15000),(16000);
|
||||
COMMIT;
|
||||
SELECT col_15 FROM testdb_wl5522.t1 WHERE col_15 > 11000;
|
||||
col_15
|
||||
15000
|
||||
16000
|
||||
ALTER TABLE testdb_wl5522.t1 DROP INDEX idx1;
|
||||
ALTER TABLE testdb_wl5522.t1 DROP INDEX idx6;
|
||||
ALTER TABLE testdb_wl5522.t1 DROP INDEX idx10;
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 15000
|
||||
NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 16000
|
||||
ALTER TABLE testdb_wl5522.t1 ADD INDEX idx1 (col_1);
|
||||
ALTER TABLE testdb_wl5522.t1 ADD INDEX idx6 (col_1(255));
|
||||
ALTER TABLE testdb_wl5522.t1 ADD INDEX idx10 (col_10(255));
|
||||
SELECT
|
||||
col_1 = REPEAT("col1_00001",10),
|
||||
col_2 = REPEAT("col2_00001",10),
|
||||
col_3 = REPEAT("col3_00001",10),
|
||||
col_4 = REPEAT("col4_00001",10),
|
||||
col_5 = REPEAT("col5_00001",10),
|
||||
col_6 = REPEAT("col6_00001",10),
|
||||
col_7 = REPEAT("col7_00001",10),
|
||||
col_8 = REPEAT("col8_00001",10),
|
||||
col_9 = REPEAT("col9_00001",10),
|
||||
col_10 = REPEAT("col10_00001",10),
|
||||
col_11 = REPEAT("col11_00001",10),
|
||||
col_12 = REPEAT("col12_00001",10),
|
||||
col_13 = REPEAT("col13_00001",10),
|
||||
col_14 = REPEAT("col14_00001",10),
|
||||
col_15
|
||||
FROM testdb_wl5522.t1;
|
||||
col_1 = REPEAT("col1_00001",10) col_2 = REPEAT("col2_00001",10) col_3 = REPEAT("col3_00001",10) col_4 = REPEAT("col4_00001",10) col_5 = REPEAT("col5_00001",10) col_6 = REPEAT("col6_00001",10) col_7 = REPEAT("col7_00001",10) col_8 = REPEAT("col8_00001",10) col_9 = REPEAT("col9_00001",10) col_10 = REPEAT("col10_00001",10) col_11 = REPEAT("col11_00001",10) col_12 = REPEAT("col12_00001",10) col_13 = REPEAT("col13_00001",10) col_14 = REPEAT("col14_00001",10) col_15
|
||||
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
|
||||
NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 15000
|
||||
NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL NULL 16000
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
SET AUTOCOMMIT = 1;
|
||||
CREATE TABLE testdb_wl5522.t1(col1 bit(1) ,
|
||||
col2 boolean,col3 tinyint , col4 smallint ,
|
||||
col5 mediumint ,col6 int , col7 bigint ,
|
||||
col8 float (14,3) ,col9 double (14,3),
|
||||
col10 VARCHAR(20) CHARACTER SET utf8 ,
|
||||
col11 TEXT CHARACTER SET binary ,
|
||||
col12 ENUM('a','b','c') CHARACTER SET binary,
|
||||
col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,
|
||||
col14 CHAR(20) , col15 VARBINARY (400),
|
||||
col16 BINARY(40), col17 BLOB (400),
|
||||
col18 int not null primary key,
|
||||
col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,
|
||||
col22 TIME , col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE TABLE testdb_wl5522.trigger_table ( i int ) ENGINE = Innodb;
|
||||
CREATE TRIGGER testdb_wl5522.tri AFTER INSERT ON testdb_wl5522.t1
|
||||
FOR EACH ROW INSERT INTO testdb_wl5522.trigger_table VALUES(NEW.col18);
|
||||
CREATE OR REPLACE VIEW testdb_wl5522.VW1 AS SELECT * FROM testdb_wl5522.t1;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
1,1,-128,32767,-8388608,2147483647,-9223372036854775808,92233720368.222,
|
||||
-92233720368.222,'aaa','aaaaaaaaaa','b','bbbbb','ccccc',REPEAT('d',40),
|
||||
REPEAT('d',40),REPEAT('d',40),1,'1000-01-01','3000-12-31 23:59:59.99',
|
||||
'1990-01-01 00:00:01.00','01:59:59.00','1901');
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,3,NULL,NULL,NULL,NULL,NULL);
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Column 'col18' cannot be null
|
||||
INSERT INTO testdb_wl5522.t1 VALUES (
|
||||
NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,
|
||||
NULL,NULL,1,NULL,NULL,NULL,NULL,NULL);
|
||||
ERROR 23000: Duplicate entry '1' for key 'PRIMARY'
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
SELECT * FROM testdb_wl5522.trigger_table;
|
||||
i
|
||||
1
|
||||
3
|
||||
SELECT COUNT(*) FROM testdb_wl5522.VW1;
|
||||
COUNT(*)
|
||||
2
|
||||
FLUSH TABLES testdb_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
CREATE TABLE testdb_wl5522.t1(col1 bit(1) ,
|
||||
col2 boolean,col3 tinyint , col4 smallint ,
|
||||
col5 mediumint ,col6 int , col7 bigint ,
|
||||
col8 float (14,3) ,col9 double (14,3),
|
||||
col10 VARCHAR(20) CHARACTER SET utf8 ,
|
||||
col11 TEXT CHARACTER SET binary ,
|
||||
col12 ENUM('a','b','c') CHARACTER SET binary,
|
||||
col13 TEXT CHARACTER SET latin1 COLLATE latin1_general_cs ,
|
||||
col14 CHAR(20) , col15 VARBINARY (400),
|
||||
col16 BINARY(40), col17 BLOB (400),
|
||||
col18 int not null primary key,
|
||||
col19 DATE ,col20 DATETIME , col21 TIMESTAMP ,
|
||||
col22 TIME , col23 YEAR ) ENGINE = Innodb;
|
||||
CREATE INDEX idx1 ON testdb_wl5522.t1(col18);
|
||||
CREATE INDEX prefix_idx ON testdb_wl5522.t1(col14 (10));
|
||||
CREATE UNIQUE INDEX idx2 ON testdb_wl5522.t1(col12);
|
||||
CREATE UNIQUE INDEX idx3 ON testdb_wl5522.t1(col8);
|
||||
ALTER TABLE testdb_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE testdb_wl5522.t1 IMPORT TABLESPACE;
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1;
|
||||
COUNT(*)
|
||||
2
|
||||
SELECT * FROM testdb_wl5522.trigger_table;
|
||||
i
|
||||
1
|
||||
3
|
||||
SELECT COUNT(*) FROM testdb_wl5522.VW1;
|
||||
COUNT(*)
|
||||
2
|
||||
INSERT INTO testdb_wl5522.t1(col18) VALUES (5);
|
||||
SELECT * FROM testdb_wl5522.trigger_table;
|
||||
i
|
||||
1
|
||||
3
|
||||
UPDATE testdb_wl5522.t1 SET col18=10 WHERE col18=1;
|
||||
SELECT COUNT(*) FROM testdb_wl5522.VW1;
|
||||
COUNT(*)
|
||||
3
|
||||
SELECT COUNT(*) FROM testdb_wl5522.t1 WHERE col18=10;
|
||||
COUNT(*)
|
||||
1
|
||||
ALTER TABLE testdb_wl5522.t1 ADD COLUMN col24 varbinary(40) default null;
|
||||
INSERT INTO testdb_wl5522.t1(col18,col24) VALUES (6,REPEAT('a',10));
|
||||
SELECT col24,col18 FROM testdb_wl5522.t1 WHERE col18 in (6,1,10) ORDER BY col18;
|
||||
col24 col18
|
||||
aaaaaaaaaa 6
|
||||
NULL 10
|
||||
ALTER TABLE testdb_wl5522.t1 DROP INDEX prefix_idx;
|
||||
SELECT col18,col14 FROM testdb_wl5522.t1 WHERE col14 like '_ccc%';
|
||||
col18 col14
|
||||
10 ccccc
|
||||
ALTER TABLE testdb_wl5522.t1 ADD INDEX prefix_idx (col24(10));
|
||||
SELECT col18,col24 FROM testdb_wl5522.t1 WHERE col24 like '_a_a%';
|
||||
col18 col24
|
||||
6 aaaaaaaaaa
|
||||
DROP TABLE testdb_wl5522.t1;
|
||||
DROP DATABASE testdb_wl5522;
|
||||
call mtr.add_suppression("Got error -1 when reading table '.*'");
|
||||
call mtr.add_suppression("InnoDB: Error: tablespace id and flags in file '.*'.*");
|
||||
call mtr.add_suppression("InnoDB: The table .* doesn't have a corresponding tablespace, it was discarded");
|
||||
SET GLOBAL INNODB_FILE_FORMAT=Antelope;
|
||||
SET GLOBAL INNODB_FILE_PER_TABLE=1;
|
580
mysql-test/suite/innodb/r/innodb-wl5522-debug-zip.result
Normal file
580
mysql-test/suite/innodb/r/innodb-wl5522-debug-zip.result
Normal file
@ -0,0 +1,580 @@
|
||||
SET GLOBAL innodb_file_per_table = 1;
|
||||
SELECT @@innodb_file_per_table;
|
||||
@@innodb_file_per_table
|
||||
1
|
||||
SET GLOBAL innodb_file_format = `Barracuda`;
|
||||
SELECT @@innodb_file_format;
|
||||
@@innodb_file_format
|
||||
Barracuda
|
||||
SET SESSION innodb_strict_mode=1;
|
||||
SELECT @@SESSION.innodb_strict_mode;
|
||||
@@SESSION.innodb_strict_mode
|
||||
1
|
||||
DROP DATABASE IF EXISTS test_wl5522;
|
||||
Warnings:
|
||||
Note 1008 Can't drop database 'test_wl5522'; database doesn't exist
|
||||
CREATE DATABASE test_wl5522;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED;
|
||||
INSERT INTO test_wl5522.t1 VALUES (1), (2), (3), (4);
|
||||
FLUSH TABLES test_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED;
|
||||
INSERT INTO test_wl5522.t1 VALUES (1);
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_before_commit_crash";
|
||||
SELECT * FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Lost connection to MySQL server during query
|
||||
SET SESSION debug_dbug="-d,ib_import_before_commit_crash";
|
||||
SET SESSION debug_dbug="+d,ib_import_before_checkpoint_crash";
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Lost connection to MySQL server during query
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
# Restart and reconnect to the server
|
||||
SET SESSION debug_dbug="-d,ib_import_before_checkpoint_crash";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
SET GLOBAL innodb_file_per_table = 1;
|
||||
SELECT @@innodb_file_per_table;
|
||||
@@innodb_file_per_table
|
||||
1
|
||||
SET GLOBAL innodb_file_format = `Barracuda`;
|
||||
SELECT @@innodb_file_format;
|
||||
@@innodb_file_format
|
||||
Barracuda
|
||||
SET SESSION innodb_strict_mode=1;
|
||||
SELECT @@SESSION.innodb_strict_mode;
|
||||
@@SESSION.innodb_strict_mode
|
||||
1
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
CHECK TABLE test_wl5522.t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test_wl5522.t1 check status OK
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
COUNT(*)
|
||||
4
|
||||
INSERT INTO test_wl5522.t1 VALUES(400), (500), (600);
|
||||
SELECT * FROM test_wl5522.t1;
|
||||
c1
|
||||
1
|
||||
2
|
||||
3
|
||||
4
|
||||
400
|
||||
500
|
||||
600
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_internal_error";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Internal error: While updating the <space, root page number> of index "GEN_CLUST_INDEX" - Generic error
|
||||
SET SESSION debug_dbug="-d,ib_import_internal_error";
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_reset_space_and_lsn_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Internal error: Cannot reset LSNs in table '"test_wl5522"."t1"' : Too many concurrent transactions
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="-d,ib_import_reset_space_and_lsn_failure";
|
||||
SET SESSION debug_dbug="+d,ib_import_open_tablespace_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Got error 44 'Tablespace not found' from ./test_wl5522/t1.ibd
|
||||
SET SESSION debug_dbug="-d,ib_import_open_tablespace_failure";
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_check_bitmap_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_check_bitmap_failure";
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_cluster_root_adjust_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_cluster_root_adjust_failure";
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_cluster_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_cluster_failure";
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_sec_root_adjust_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_sec_root_adjust_failure";
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_set_max_rowid_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_set_max_rowid_failure";
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (
|
||||
c1 BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
||||
c2 BIGINT,
|
||||
c3 VARCHAR(2048),
|
||||
c4 VARCHAR(2048),
|
||||
INDEX idx1(c2),
|
||||
INDEX idx2(c3(512)),
|
||||
INDEX idx3(c4(512))) Engine=InnoDB
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8;
|
||||
SET GLOBAL INNODB_PURGE_STOP_NOW=ON;
|
||||
SET GLOBAL innodb_disable_background_merge=ON;
|
||||
SET GLOBAL innodb_monitor_reset = ibuf_merges;
|
||||
SET GLOBAL innodb_monitor_reset = ibuf_merges_insert;
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) VALUES
|
||||
(1, REPEAT('a', 2048), REPEAT('a', 2048)),
|
||||
(2, REPEAT('b', 2048), REPEAT('b', 2048)),
|
||||
(3, REPEAT('c', 2048), REPEAT('c', 2048)),
|
||||
(4, REPEAT('d', 2048), REPEAT('d', 2048));
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) SELECT c2, c3, c4 FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) SELECT c2, c3, c4 FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) SELECT c2, c3, c4 FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) SELECT c2, c3, c4 FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1(c2, c3, c4) SELECT c2, c3, c4 FROM test_wl5522.t1;
|
||||
DELETE FROM test_wl5522.t1 WHERE c2 = 1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c2 = c2 + c1;
|
||||
UPDATE test_wl5522.t1 SET c3 = REPEAT("c2", 1024);
|
||||
UPDATE test_wl5522.t1 SET c4 = REPEAT("c4", 1024);
|
||||
SHOW CREATE TABLE test_wl5522.t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`c1` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||
`c2` bigint(20) DEFAULT NULL,
|
||||
`c3` varchar(2048) DEFAULT NULL,
|
||||
`c4` varchar(2048) DEFAULT NULL,
|
||||
PRIMARY KEY (`c1`),
|
||||
KEY `idx1` (`c2`),
|
||||
KEY `idx2` (`c3`(512)),
|
||||
KEY `idx3` (`c4`(512))
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=248 DEFAULT CHARSET=latin1 ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8
|
||||
SELECT c1, c2 FROM test_wl5522.t1;
|
||||
c1 c2
|
||||
2 32
|
||||
3 48
|
||||
4 64
|
||||
6 92
|
||||
7 108
|
||||
8 124
|
||||
13 197
|
||||
14 213
|
||||
15 229
|
||||
17 257
|
||||
18 273
|
||||
19 289
|
||||
28 422
|
||||
29 438
|
||||
30 454
|
||||
32 482
|
||||
33 498
|
||||
34 514
|
||||
36 542
|
||||
37 558
|
||||
38 574
|
||||
40 602
|
||||
41 618
|
||||
42 634
|
||||
59 887
|
||||
60 903
|
||||
61 919
|
||||
63 947
|
||||
64 963
|
||||
65 979
|
||||
67 1007
|
||||
68 1023
|
||||
69 1039
|
||||
71 1067
|
||||
72 1083
|
||||
73 1099
|
||||
75 1127
|
||||
76 1143
|
||||
77 1159
|
||||
79 1187
|
||||
80 1203
|
||||
81 1219
|
||||
83 1247
|
||||
84 1263
|
||||
85 1279
|
||||
87 1307
|
||||
88 1323
|
||||
89 1339
|
||||
122 1832
|
||||
123 1848
|
||||
124 1864
|
||||
126 1892
|
||||
127 1908
|
||||
128 1924
|
||||
130 1952
|
||||
131 1968
|
||||
132 1984
|
||||
134 2012
|
||||
135 2028
|
||||
136 2044
|
||||
138 2072
|
||||
139 2088
|
||||
140 2104
|
||||
142 2132
|
||||
143 2148
|
||||
144 2164
|
||||
146 2192
|
||||
147 2208
|
||||
148 2224
|
||||
150 2252
|
||||
151 2268
|
||||
152 2284
|
||||
154 2312
|
||||
155 2328
|
||||
156 2344
|
||||
158 2372
|
||||
159 2388
|
||||
160 2404
|
||||
162 2432
|
||||
163 2448
|
||||
164 2464
|
||||
166 2492
|
||||
167 2508
|
||||
168 2524
|
||||
170 2552
|
||||
171 2568
|
||||
172 2584
|
||||
174 2612
|
||||
175 2628
|
||||
176 2644
|
||||
178 2672
|
||||
179 2688
|
||||
180 2704
|
||||
182 2732
|
||||
183 2748
|
||||
184 2764
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
COUNT(*)
|
||||
96
|
||||
SELECT SUM(c2) FROM test_wl5522.t1;
|
||||
SUM(c2)
|
||||
145278
|
||||
SELECT name
|
||||
FROM information_schema.innodb_metrics
|
||||
WHERE name = 'ibuf_merges_insert' AND count = 0;
|
||||
name
|
||||
FLUSH TABLES test_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
SELECT name
|
||||
FROM information_schema.innodb_metrics
|
||||
WHERE name = 'ibuf_merges' AND count > 0;
|
||||
name
|
||||
ibuf_merges
|
||||
SELECT name
|
||||
FROM information_schema.innodb_metrics
|
||||
WHERE name = 'ibuf_merges_inserts' AND count > 0;
|
||||
name
|
||||
SET GLOBAL innodb_disable_background_merge=OFF;
|
||||
SET GLOBAL INNODB_PURGE_RUN_NOW=ON;
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (
|
||||
c1 BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
||||
c2 BIGINT,
|
||||
c3 VARCHAR(2048),
|
||||
c4 VARCHAR(2048),
|
||||
INDEX idx1(c2),
|
||||
INDEX idx2(c3(512)),
|
||||
INDEX idx3(c4(512))) Engine=InnoDB
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8;
|
||||
SELECT c1, c2 FROM test_wl5522.t1;
|
||||
c1 c2
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
restore: t1 .ibd and .cfg files
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
CHECK TABLE test_wl5522.t1;
|
||||
Table Op Msg_type Msg_text
|
||||
test_wl5522.t1 check status OK
|
||||
SELECT c1,c2 FROM test_wl5522.t1;
|
||||
c1 c2
|
||||
2 32
|
||||
3 48
|
||||
4 64
|
||||
6 92
|
||||
7 108
|
||||
8 124
|
||||
13 197
|
||||
14 213
|
||||
15 229
|
||||
17 257
|
||||
18 273
|
||||
19 289
|
||||
28 422
|
||||
29 438
|
||||
30 454
|
||||
32 482
|
||||
33 498
|
||||
34 514
|
||||
36 542
|
||||
37 558
|
||||
38 574
|
||||
40 602
|
||||
41 618
|
||||
42 634
|
||||
59 887
|
||||
60 903
|
||||
61 919
|
||||
63 947
|
||||
64 963
|
||||
65 979
|
||||
67 1007
|
||||
68 1023
|
||||
69 1039
|
||||
71 1067
|
||||
72 1083
|
||||
73 1099
|
||||
75 1127
|
||||
76 1143
|
||||
77 1159
|
||||
79 1187
|
||||
80 1203
|
||||
81 1219
|
||||
83 1247
|
||||
84 1263
|
||||
85 1279
|
||||
87 1307
|
||||
88 1323
|
||||
89 1339
|
||||
122 1832
|
||||
123 1848
|
||||
124 1864
|
||||
126 1892
|
||||
127 1908
|
||||
128 1924
|
||||
130 1952
|
||||
131 1968
|
||||
132 1984
|
||||
134 2012
|
||||
135 2028
|
||||
136 2044
|
||||
138 2072
|
||||
139 2088
|
||||
140 2104
|
||||
142 2132
|
||||
143 2148
|
||||
144 2164
|
||||
146 2192
|
||||
147 2208
|
||||
148 2224
|
||||
150 2252
|
||||
151 2268
|
||||
152 2284
|
||||
154 2312
|
||||
155 2328
|
||||
156 2344
|
||||
158 2372
|
||||
159 2388
|
||||
160 2404
|
||||
162 2432
|
||||
163 2448
|
||||
164 2464
|
||||
166 2492
|
||||
167 2508
|
||||
168 2524
|
||||
170 2552
|
||||
171 2568
|
||||
172 2584
|
||||
174 2612
|
||||
175 2628
|
||||
176 2644
|
||||
178 2672
|
||||
179 2688
|
||||
180 2704
|
||||
182 2732
|
||||
183 2748
|
||||
184 2764
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
COUNT(*)
|
||||
96
|
||||
SELECT SUM(c2) FROM test_wl5522.t1;
|
||||
SUM(c2)
|
||||
145278
|
||||
SHOW CREATE TABLE test_wl5522.t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`c1` bigint(20) NOT NULL AUTO_INCREMENT,
|
||||
`c2` bigint(20) DEFAULT NULL,
|
||||
`c3` varchar(2048) DEFAULT NULL,
|
||||
`c4` varchar(2048) DEFAULT NULL,
|
||||
PRIMARY KEY (`c1`),
|
||||
KEY `idx1` (`c2`),
|
||||
KEY `idx2` (`c3`(512)),
|
||||
KEY `idx3` (`c4`(512))
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=185 DEFAULT CHARSET=latin1 ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
INSERT INTO test_wl5522.t1 VALUES
|
||||
(100, REPEAT('Karanbir', 899), REPEAT('Ajeeth', 1200));
|
||||
Warnings:
|
||||
Warning 1265 Data truncated for column 'c2' at row 1
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
INSERT INTO test_wl5522.t1 SELECT * FROM test_wl5522.t1;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
COUNT(*)
|
||||
256
|
||||
FLUSH TABLES test_wl5522.t1 FOR EXPORT;
|
||||
backup: t1
|
||||
UNLOCK TABLES;
|
||||
DROP TABLE test_wl5522.t1;
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_trigger_corruption_1";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Internal error: Cannot reset LSNs in table '"test_wl5522"."t1"' : Data structure corruption
|
||||
SET SESSION debug_dbug="-d,ib_import_trigger_corruption_1";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,buf_page_is_corrupt_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
SET SESSION debug_dbug="-d,buf_page_is_corrupt_failure";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_trigger_corruption_2";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Index corrupt: Externally stored column(5) has a reference length of 19 in the cluster index "GEN_CLUST_INDEX"
|
||||
SET SESSION debug_dbug="-d,ib_import_trigger_corruption_2";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,ib_import_trigger_corruption_3";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Incorrect key file for table 't1'; try to repair it
|
||||
SET SESSION debug_dbug="-d,ib_import_trigger_corruption_3";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
SET SESSION debug_dbug="+d,ib_import_create_index_failure_1";
|
||||
ALTER TABLE test_wl5522.t1 ADD INDEX idx(c1);
|
||||
Warnings:
|
||||
Warning 1814 Tablespace has been discarded for table 't1'
|
||||
SET SESSION debug_dbug="-d,ib_import_create_index_failure_1";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,fil_space_create_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Got error 11 'Generic error' from ./test_wl5522/t1.ibd
|
||||
SET SESSION debug_dbug="-d,fil_space_create_failure";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,dict_tf_to_fsp_flags_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Got error 39 'Data structure corruption' from ./test_wl5522/t1.ibd
|
||||
SET SESSION debug_dbug="-d,dict_tf_to_fsp_flags_failure";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
CREATE TABLE test_wl5522.t1 (c1 INT, c2 VARCHAR(1024), c3 BLOB) ENGINE = Innodb
|
||||
ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
|
||||
ALTER TABLE test_wl5522.t1 DISCARD TABLESPACE;
|
||||
SELECT COUNT(*) FROM test_wl5522.t1;
|
||||
ERROR HY000: Tablespace has been discarded for table 't1'
|
||||
restore: t1 .ibd and .cfg files
|
||||
SET SESSION debug_dbug="+d,fsp_flags_is_valid_failure";
|
||||
ALTER TABLE test_wl5522.t1 IMPORT TABLESPACE;
|
||||
ERROR HY000: Internal error: Cannot reset LSNs in table '"test_wl5522"."t1"' : Unsupported
|
||||
SET SESSION debug_dbug="-d,fsp_flags_is_valid_failure";
|
||||
DROP TABLE test_wl5522.t1;
|
||||
unlink: t1.ibd
|
||||
unlink: t1.cfg
|
||||
DROP DATABASE test_wl5522;
|
||||
set global innodb_monitor_disable = all;
|
||||
set global innodb_monitor_reset_all = all;
|
||||
set global innodb_monitor_enable = default;
|
||||
set global innodb_monitor_disable = default;
|
||||
set global innodb_monitor_reset = default;
|
||||
set global innodb_monitor_reset_all = default;
|
||||
SET GLOBAL INNODB_FILE_PER_TABLE=1;
|
||||
SET GLOBAL INNODB_FILE_FORMAT=Antelope;
|
||||
SET SESSION innodb_strict_mode=0;
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user