diff options
author | hf@deer.(none) <> | 2003-07-14 12:40:58 +0500 |
---|---|---|
committer | hf@deer.(none) <> | 2003-07-14 12:40:58 +0500 |
commit | 9b4ebf3d295ff7b8a3501ec113e3bdd67703fdb6 (patch) | |
tree | 68da54f595c64ddbe52b1d77fcc1a9febbe0b56b /myisam | |
parent | f7570df170baad076fe6eabda60399e0bf7833fb (diff) | |
download | mariadb-git-9b4ebf3d295ff7b8a3501ec113e3bdd67703fdb6.tar.gz |
Proposed bugfix for #712
Monty revoked any locks for temporary tables in
ha_myisam::external_lock()
But further code bans using write cache on nonlocked tables
this makes operations much slower
Diffstat (limited to 'myisam')
-rw-r--r-- | myisam/mi_locking.c | 8 | ||||
-rw-r--r-- | myisam/myisamdef.h | 1 |
2 files changed, 9 insertions, 0 deletions
diff --git a/myisam/mi_locking.c b/myisam/mi_locking.c index cbde05d31f5..648c447ae30 100644 --- a/myisam/mi_locking.c +++ b/myisam/mi_locking.c @@ -39,6 +39,14 @@ int mi_lock_database(MI_INFO *info, int lock_type) if (share->options & HA_OPTION_READ_ONLY_DATA || info->lock_type == lock_type) DBUG_RETURN(0); + if (lock_type == MI_TEMPORARY_TABLE) + { + ++share->w_locks; + ++share->tot_locks; + info->lock_type= lock_type; + DBUG_RETURN(0); + } + flag=error=0; pthread_mutex_lock(&share->intern_lock); if (share->kfile >= 0) /* May only be false on windows */ diff --git a/myisam/myisamdef.h b/myisam/myisamdef.h index 7631b245b9b..9c2f34990ed 100644 --- a/myisam/myisamdef.h +++ b/myisam/myisamdef.h @@ -101,6 +101,7 @@ typedef struct st_mi_state_info #define MI_COLUMNDEF_SIZE (2*3+1) #define MI_BASE_INFO_SIZE (5*8 + 8*4 + 4 + 4*2 + 16) #define MI_INDEX_BLOCK_MARGIN 16 /* Safety margin for .MYI tables */ +#define MI_TEMPORARY_TABLE ((1 & ~F_RDLCK) | (2 & ~F_WRLCK) | (4 & ~F_UNLCK)) typedef struct st_mi_base_info { |