mirror of
https://github.com/MariaDB/server.git
synced 2025-01-28 01:34:17 +01:00
7b8bfb2a93
Bug#12093 "SP not found on second PS execution if another thread drops other SP in between" and Bug#21294 "executing a prepared statement that executes a stored function which was recreat" Stored functions are resolved at prepared statement prepare only. If someone flushes the stored functions cache between prepare and execute, execution fails. The fix is to detect the situation of the cache flush and automatically reprepare the prepared statement after it. mysql-test/r/ps_ddl.result: Update results (Bug#12093 and Bug#21294, the test cases are already in the source tree). mysql-test/r/ps_ddl1.result: Update results (Bug#12093 and Bug#21294, the test cases are already in the source tree). mysql-test/r/sp-error.result: Update results (Bug#12093 and Bug#21294, the test cases are already in the source tree). mysql-test/t/ps_ddl.test: Modify the test to not expect an error where there is no error any more (Bug#12093, Bug#21294). mysql-test/t/ps_ddl1.test: Modify the test to not expect an error where there is no error any more (Bug#12093, Bug#21294). mysql-test/t/sp-error.test: Modify the test to not expect an error where there is no error any more (Bug#12093, Bug#21294). sql/sp_cache.cc: Implement sp_cache_version() -- returns the current version of a stored routines cache. sql/sp_cache.h: Declare sp_cache_version(). sql/sql_prepare.cc: Keep track of stored functions cache version, and invalidate the statement if it changed between prepared statement prepare and execute (and the statement actually uses stored routines).
63 lines
1.8 KiB
C++
63 lines
1.8 KiB
C++
/* -*- C++ -*- */
|
|
/* Copyright (C) 2002 MySQL AB
|
|
|
|
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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
#ifndef _SP_CACHE_H_
|
|
#define _SP_CACHE_H_
|
|
|
|
#ifdef USE_PRAGMA_INTERFACE
|
|
#pragma interface /* gcc class implementation */
|
|
#endif
|
|
|
|
/*
|
|
Stored procedures/functions cache. This is used as follows:
|
|
* Each thread has its own cache.
|
|
* Each sp_head object is put into its thread cache before it is used, and
|
|
then remains in the cache until deleted.
|
|
*/
|
|
|
|
class sp_head;
|
|
class sp_cache;
|
|
|
|
/*
|
|
Cache usage scenarios:
|
|
1. Application-wide init:
|
|
sp_cache_init();
|
|
|
|
2. SP execution in thread:
|
|
2.1 While holding sp_head* pointers:
|
|
|
|
// look up a routine in the cache (no checks if it is up to date or not)
|
|
sp_cache_lookup();
|
|
|
|
sp_cache_insert();
|
|
sp_cache_invalidate();
|
|
|
|
2.2 When not holding any sp_head* pointers:
|
|
sp_cache_flush_obsolete();
|
|
|
|
3. Before thread exit:
|
|
sp_cache_clear();
|
|
*/
|
|
|
|
void sp_cache_init();
|
|
void sp_cache_clear(sp_cache **cp);
|
|
void sp_cache_insert(sp_cache **cp, sp_head *sp);
|
|
sp_head *sp_cache_lookup(sp_cache **cp, sp_name *name);
|
|
void sp_cache_invalidate();
|
|
void sp_cache_flush_obsolete(sp_cache **cp);
|
|
ulong sp_cache_version(sp_cache **cp);
|
|
|
|
#endif /* _SP_CACHE_H_ */
|