mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
merge with mysql-5.5.30 minus few incorrect or not applicable changesets
This commit is contained in:
@ -3123,8 +3123,8 @@ void Query_cache::invalidate_table(THD *thd, TABLE_LIST *table_list)
|
||||
char key[MAX_DBKEY_LENGTH];
|
||||
uint key_length;
|
||||
|
||||
key_length=(uint) (strmov(strmov(key,table_list->db)+1,
|
||||
table_list->table_name) -key)+ 1;
|
||||
key_length= create_table_def_key(key, table_list->db,
|
||||
table_list->table_name);
|
||||
|
||||
// We don't store temporary tables => no key_length+=4 ...
|
||||
invalidate_table(thd, (uchar *)key, key_length);
|
||||
@ -3242,8 +3242,8 @@ Query_cache::register_tables_from_list(THD *thd, TABLE_LIST *tables_used,
|
||||
DBUG_PRINT("qcache", ("view: %s db: %s",
|
||||
tables_used->view_name.str,
|
||||
tables_used->view_db.str));
|
||||
key_length= (uint) (strmov(strmov(key, tables_used->view_db.str) + 1,
|
||||
tables_used->view_name.str) - key) + 1;
|
||||
key_length= create_table_def_key(key, tables_used->view_db.str,
|
||||
tables_used->view_name.str);
|
||||
/*
|
||||
There are not callback function for for VIEWs
|
||||
*/
|
||||
@ -4287,15 +4287,14 @@ my_bool Query_cache::move_by_type(uchar **border,
|
||||
case Query_cache_block::RES_CONT:
|
||||
case Query_cache_block::RESULT:
|
||||
{
|
||||
DBUG_PRINT("qcache", ("block 0x%lx RES* (%d)", (ulong) block,
|
||||
(int) block->type));
|
||||
if (*border == 0)
|
||||
break;
|
||||
Query_cache_block *query_block = block->result()->parent(),
|
||||
*next = block->next,
|
||||
*prev = block->prev;
|
||||
Query_cache_block::block_type type = block->type;
|
||||
BLOCK_LOCK_WR(query_block);
|
||||
DBUG_PRINT("qcache", ("block 0x%lx RES* (%d)", (ulong) block,
|
||||
(int) block->type));
|
||||
if (*border == 0)
|
||||
break;
|
||||
Query_cache_block *query_block= block->result()->parent();
|
||||
BLOCK_LOCK_WR(query_block);
|
||||
Query_cache_block *next= block->next, *prev= block->prev;
|
||||
Query_cache_block::block_type type= block->type;
|
||||
ulong len = block->length, used = block->used;
|
||||
Query_cache_block *pprev = block->pprev,
|
||||
*pnext = block->pnext,
|
||||
@ -4457,8 +4456,9 @@ uint Query_cache::filename_2_table_key (char *key, const char *path,
|
||||
*db_length= (filename - dbname) - 1;
|
||||
DBUG_PRINT("qcache", ("table '%-.*s.%s'", *db_length, dbname, filename));
|
||||
|
||||
DBUG_RETURN((uint) (strmov(strmake(key, dbname, *db_length) + 1,
|
||||
filename) -key) + 1);
|
||||
DBUG_RETURN((uint) (strmake(strmake(key, dbname,
|
||||
min(*db_length, NAME_LEN)) + 1,
|
||||
filename, NAME_LEN) - key) + 1);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
|
Reference in New Issue
Block a user