Loading mysql-test/r/query_cache.result +4 −4 Original line number Diff line number Diff line Loading @@ -566,7 +566,7 @@ select * from t1; a set GLOBAL query_cache_size=1024; Warnings: Warning 1282 Query cache failed to set size 1024 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 1024; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -574,7 +574,7 @@ select * from t1; a set GLOBAL query_cache_size=10240; Warnings: Warning 1282 Query cache failed to set size 10240 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 10240; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -582,7 +582,7 @@ select * from t1; a set GLOBAL query_cache_size=20480; Warnings: Warning 1282 Query cache failed to set size 20480 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 20480; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -590,7 +590,7 @@ select * from t1; a set GLOBAL query_cache_size=40960; Warnings: Warning 1282 Query cache failed to set size 40960 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 40960; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading sql/set_var.cc +13 −1 Original line number Diff line number Diff line Loading @@ -1046,7 +1046,19 @@ static void fix_net_retry_count(THD *thd __attribute__((unused)), static void fix_query_cache_size(THD *thd, enum_var_type type) { #ifdef HAVE_QUERY_CACHE query_cache_size= query_cache.resize(query_cache_size); ulong new_cache_size= query_cache.resize(query_cache_size); /* Note: query_cache_size is a global variable reflecting the requested cache size. See also query_cache_size_arg */ if (query_cache_size != new_cache_size) push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN, ER_WARN_QC_RESIZE, ER(ER_WARN_QC_RESIZE), query_cache_size, new_cache_size); query_cache_size= new_cache_size; #endif } Loading sql/share/errmsg.txt +7 −7 Original line number Diff line number Diff line Loading @@ -4995,13 +4995,13 @@ ER_WRONG_NAME_FOR_CATALOG 42000 spa "Nombre de catalog incorrecto '%-.100s'" swe "Felaktigt katalog namn '%-.100s'" ER_WARN_QC_RESIZE eng "Query cache failed to set size %lu (minimal value: %lu); new query cache size is %lu" ger "nderung der Query-Cache-Gre auf %lu (Minimale Zahl: %lu) fehlgeschlagen; neue Query-Cache-Gre ist %lu" por "Falha em Query cache para configurar tamanho %lu (Nmero mnimo: %lu), novo tamanho de query cache %lu" rus " %lu (minimal value: %lu), - %lu" spa "Query cache fallada para configurar tamao %lu (Nmero mnimo: %lu), nuevo tamao de query cache es %lu" swe "Storleken av "Query cache" kunde inte sttas till %lu (minsta vrde: %lu); ny storlek r %lu" ukr " Ԧ ͦ %lu (minimal value: %lu), ͦ Ԧ - %lu" eng "Query cache failed to set size %lu; new query cache size is %lu" ger "nderung der Query-Cache-Gre auf %lu fehlgeschlagen; neue Query-Cache-Gre ist %lu" por "Falha em Query cache para configurar tamanho %lu, novo tamanho de query cache %lu" rus " %lu, - %lu" spa "Query cache fallada para configurar tamao %lu, nuevo tamao de query cache es %lu" swe "Storleken av "Query cache" kunde inte sttas till %lu, ny storlek r %lu" ukr " Ԧ ͦ %lu, ͦ Ԧ - %lu" ER_BAD_FT_COLUMN eng "Column '%-.192s' cannot be part of FULLTEXT index" ger "Feld '%-.192s' kann nicht Teil eines FULLTEXT-Index sein" Loading sql/sql_cache.cc +5 −30 Original line number Diff line number Diff line Loading @@ -942,25 +942,18 @@ ulong Query_cache::resize(ulong query_cache_size_arg) } while (block != queries_blocks); } free_cache(); query_cache_size= query_cache_size_arg; ::query_cache_size= init_cache(); if (::query_cache_size != query_cache_size_arg) { push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN, ER_WARN_QC_RESIZE, ER(ER_WARN_QC_RESIZE), query_cache_size_arg, get_minimal_size_limit(), ::query_cache_size); } query_cache_size= query_cache_size_arg; new_query_cache_size= init_cache(); STRUCT_LOCK(&structure_guard_mutex); m_cache_status= Query_cache::NO_FLUSH_IN_PROGRESS; pthread_cond_signal(&COND_cache_status_changed); if (new_query_cache_size) DBUG_EXECUTE("check_querycache",check_integrity(1);); STRUCT_UNLOCK(&structure_guard_mutex); DBUG_RETURN(::query_cache_size); DBUG_RETURN(new_query_cache_size); } Loading Loading @@ -1823,24 +1816,6 @@ void Query_cache::init() DBUG_VOID_RETURN; } /** Return the lowest possible query cache size. */ ulong Query_cache::get_minimal_size_limit() { ulong approx_additional_data_size= (sizeof(Query_cache) + sizeof(void*)*(def_query_hash_size+ def_table_hash_size)); ulong data_size= (min_allocation_unit << QUERY_CACHE_MEM_BIN_STEP_PWR2 << QUERY_CACHE_MEM_BIN_FIRST_STEP_PWR2) + ALIGN_SIZE(1) - 1 + (1 << QUERY_CACHE_MEM_BIN_STEP_PWR2) - 1 + (1 << QUERY_CACHE_MEM_BIN_FIRST_STEP_PWR2) - 1; return(data_size + approx_additional_data_size); } ulong Query_cache::init_cache() { Loading sql/sql_cache.h +0 −2 Original line number Diff line number Diff line Loading @@ -282,8 +282,6 @@ class Query_cache void free_query_internal(Query_cache_block *point); void invalidate_table_internal(THD *thd, uchar *key, uint32 key_length); ulong get_minimal_size_limit(); protected: /* The following mutex is locked when searching or changing global Loading Loading
mysql-test/r/query_cache.result +4 −4 Original line number Diff line number Diff line Loading @@ -566,7 +566,7 @@ select * from t1; a set GLOBAL query_cache_size=1024; Warnings: Warning 1282 Query cache failed to set size 1024 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 1024; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -574,7 +574,7 @@ select * from t1; a set GLOBAL query_cache_size=10240; Warnings: Warning 1282 Query cache failed to set size 10240 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 10240; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -582,7 +582,7 @@ select * from t1; a set GLOBAL query_cache_size=20480; Warnings: Warning 1282 Query cache failed to set size 20480 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 20480; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading @@ -590,7 +590,7 @@ select * from t1; a set GLOBAL query_cache_size=40960; Warnings: Warning 1282 Query cache failed to set size 40960 (minimal value: 41297); new query cache size is 0 Warning 1282 Query cache failed to set size 40960; new query cache size is 0 show global variables like "query_cache_size"; Variable_name Value query_cache_size 0 Loading
sql/set_var.cc +13 −1 Original line number Diff line number Diff line Loading @@ -1046,7 +1046,19 @@ static void fix_net_retry_count(THD *thd __attribute__((unused)), static void fix_query_cache_size(THD *thd, enum_var_type type) { #ifdef HAVE_QUERY_CACHE query_cache_size= query_cache.resize(query_cache_size); ulong new_cache_size= query_cache.resize(query_cache_size); /* Note: query_cache_size is a global variable reflecting the requested cache size. See also query_cache_size_arg */ if (query_cache_size != new_cache_size) push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN, ER_WARN_QC_RESIZE, ER(ER_WARN_QC_RESIZE), query_cache_size, new_cache_size); query_cache_size= new_cache_size; #endif } Loading
sql/share/errmsg.txt +7 −7 Original line number Diff line number Diff line Loading @@ -4995,13 +4995,13 @@ ER_WRONG_NAME_FOR_CATALOG 42000 spa "Nombre de catalog incorrecto '%-.100s'" swe "Felaktigt katalog namn '%-.100s'" ER_WARN_QC_RESIZE eng "Query cache failed to set size %lu (minimal value: %lu); new query cache size is %lu" ger "nderung der Query-Cache-Gre auf %lu (Minimale Zahl: %lu) fehlgeschlagen; neue Query-Cache-Gre ist %lu" por "Falha em Query cache para configurar tamanho %lu (Nmero mnimo: %lu), novo tamanho de query cache %lu" rus " %lu (minimal value: %lu), - %lu" spa "Query cache fallada para configurar tamao %lu (Nmero mnimo: %lu), nuevo tamao de query cache es %lu" swe "Storleken av "Query cache" kunde inte sttas till %lu (minsta vrde: %lu); ny storlek r %lu" ukr " Ԧ ͦ %lu (minimal value: %lu), ͦ Ԧ - %lu" eng "Query cache failed to set size %lu; new query cache size is %lu" ger "nderung der Query-Cache-Gre auf %lu fehlgeschlagen; neue Query-Cache-Gre ist %lu" por "Falha em Query cache para configurar tamanho %lu, novo tamanho de query cache %lu" rus " %lu, - %lu" spa "Query cache fallada para configurar tamao %lu, nuevo tamao de query cache es %lu" swe "Storleken av "Query cache" kunde inte sttas till %lu, ny storlek r %lu" ukr " Ԧ ͦ %lu, ͦ Ԧ - %lu" ER_BAD_FT_COLUMN eng "Column '%-.192s' cannot be part of FULLTEXT index" ger "Feld '%-.192s' kann nicht Teil eines FULLTEXT-Index sein" Loading
sql/sql_cache.cc +5 −30 Original line number Diff line number Diff line Loading @@ -942,25 +942,18 @@ ulong Query_cache::resize(ulong query_cache_size_arg) } while (block != queries_blocks); } free_cache(); query_cache_size= query_cache_size_arg; ::query_cache_size= init_cache(); if (::query_cache_size != query_cache_size_arg) { push_warning_printf(current_thd, MYSQL_ERROR::WARN_LEVEL_WARN, ER_WARN_QC_RESIZE, ER(ER_WARN_QC_RESIZE), query_cache_size_arg, get_minimal_size_limit(), ::query_cache_size); } query_cache_size= query_cache_size_arg; new_query_cache_size= init_cache(); STRUCT_LOCK(&structure_guard_mutex); m_cache_status= Query_cache::NO_FLUSH_IN_PROGRESS; pthread_cond_signal(&COND_cache_status_changed); if (new_query_cache_size) DBUG_EXECUTE("check_querycache",check_integrity(1);); STRUCT_UNLOCK(&structure_guard_mutex); DBUG_RETURN(::query_cache_size); DBUG_RETURN(new_query_cache_size); } Loading Loading @@ -1823,24 +1816,6 @@ void Query_cache::init() DBUG_VOID_RETURN; } /** Return the lowest possible query cache size. */ ulong Query_cache::get_minimal_size_limit() { ulong approx_additional_data_size= (sizeof(Query_cache) + sizeof(void*)*(def_query_hash_size+ def_table_hash_size)); ulong data_size= (min_allocation_unit << QUERY_CACHE_MEM_BIN_STEP_PWR2 << QUERY_CACHE_MEM_BIN_FIRST_STEP_PWR2) + ALIGN_SIZE(1) - 1 + (1 << QUERY_CACHE_MEM_BIN_STEP_PWR2) - 1 + (1 << QUERY_CACHE_MEM_BIN_FIRST_STEP_PWR2) - 1; return(data_size + approx_additional_data_size); } ulong Query_cache::init_cache() { Loading
sql/sql_cache.h +0 −2 Original line number Diff line number Diff line Loading @@ -282,8 +282,6 @@ class Query_cache void free_query_internal(Query_cache_block *point); void invalidate_table_internal(THD *thd, uchar *key, uint32 key_length); ulong get_minimal_size_limit(); protected: /* The following mutex is locked when searching or changing global Loading