summaryrefslogtreecommitdiff
path: root/sql
diff options
context:
space:
mode:
authorunknown <bell@sanja.is.com.ua>2005-06-14 22:45:48 +0300
committerunknown <bell@sanja.is.com.ua>2005-06-14 22:45:48 +0300
commite1c2646a0c9c589e41912283210785f9f9d17645 (patch)
tree245f09eed7f3ce616ac752aa5162da8e79937ba0 /sql
parentd5600efdc1ec98c1b9ef7190565788e7174e45f0 (diff)
downloadmariadb-git-e1c2646a0c9c589e41912283210785f9f9d17645.tar.gz
prohibit opening Query cache for SP cursors (BUG#9715)
mysql-test/r/query_cache.result: testing cursors in SP with QC testing suspicious but working using selects in function with QC mysql-test/t/query_cache.test: testing cursors in SP with QC testing suspicious but working using selects in function with QC sql/sp_head.h: method for prohibiting of QC using SP query sql/sp_rcontext.cc: prohibit opening Query cache for SP cursors sql/sp_rcontext.h: constructor moved to .cc file to be able to use methods from lex_keeper
Diffstat (limited to 'sql')
-rw-r--r--sql/sp_head.h4
-rw-r--r--sql/sp_rcontext.cc11
-rw-r--r--sql/sp_rcontext.h6
3 files changed, 16 insertions, 5 deletions
diff --git a/sql/sp_head.h b/sql/sp_head.h
index 49eabce246b..617d6622037 100644
--- a/sql/sp_head.h
+++ b/sql/sp_head.h
@@ -377,6 +377,10 @@ public:
return (uint)m_lex->sql_command;
}
+ void disable_query_cache()
+ {
+ m_lex->safe_to_cache_query= 0;
+ }
private:
LEX *m_lex;
diff --git a/sql/sp_rcontext.cc b/sql/sp_rcontext.cc
index 61cd7a9300f..aacb9254753 100644
--- a/sql/sp_rcontext.cc
+++ b/sql/sp_rcontext.cc
@@ -169,6 +169,17 @@ sp_rcontext::pop_cursors(uint count)
*
*/
+sp_cursor::sp_cursor(sp_lex_keeper *lex_keeper)
+ :m_lex_keeper(lex_keeper), m_prot(NULL), m_isopen(0), m_current_row(NULL)
+{
+ /*
+ currsor can't be stored in QC, so we should prevent opening QC for
+ try to write results which are absent.
+ */
+ lex_keeper->disable_query_cache();
+}
+
+
/*
pre_open cursor
diff --git a/sql/sp_rcontext.h b/sql/sp_rcontext.h
index 864dc3df146..b188805435f 100644
--- a/sql/sp_rcontext.h
+++ b/sql/sp_rcontext.h
@@ -203,11 +203,7 @@ class sp_cursor : public Sql_alloc
{
public:
- sp_cursor(sp_lex_keeper *lex_keeper)
- : m_lex_keeper(lex_keeper), m_prot(NULL), m_isopen(0), m_current_row(NULL)
- {
- /* Empty */
- }
+ sp_cursor(sp_lex_keeper *lex_keeper);
virtual ~sp_cursor()
{