diff options
author | unknown <pappa@c-5608e253.1238-1-64736c10.cust.bredbandsbolaget.se> | 2005-11-08 00:26:37 -0500 |
---|---|---|
committer | unknown <pappa@c-5608e253.1238-1-64736c10.cust.bredbandsbolaget.se> | 2005-11-08 00:26:37 -0500 |
commit | bba73a091031e9c324fedd6ad1bb26bcd4e635f9 (patch) | |
tree | c9d5aa727d72266be0ab83ff53f139f4209b6e51 /include/heap.h | |
parent | 0e878d7e541983757bc0b31e7caa8a16a5fd2896 (diff) | |
download | mariadb-git-bba73a091031e9c324fedd6ad1bb26bcd4e635f9.tar.gz |
Bug #12796: Record lost in HEAP table
Two handler objects were present, one was used for an insert and the other for a select
The state of the statistics was local to the handler object and thus the other handler
object didn't notice the insert.
Fix included:
1) Add a new variable key_stat_version added to whenever statistics was considered in need
of update (previously key_stats_ok= FALSE in those places)
2) Add a new handler variable key_stat_version assigned whenever key_stats_ok= TRUE was set
previously
3) Fix records_in_range to return records if records <= 1
4) Fix records_in_range to add 2 to rec_per_key to ensure we don't specify 0 or 1 when it isn't
and thus invoking incorrect optimisations.
5) Fix unique key handling for HEAP table in records_in_range
Diffstat (limited to 'include/heap.h')
-rw-r--r-- | include/heap.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/include/heap.h b/include/heap.h index badec9ce2ef..cfbb6113f86 100644 --- a/include/heap.h +++ b/include/heap.h @@ -136,6 +136,7 @@ typedef struct st_heap_share HP_KEYDEF *keydef; ulong min_records,max_records; /* Params to open */ ulong data_length,index_length,max_table_size; + uint key_stat_version; /* version to indicate insert/delete */ uint records; /* records */ uint blength; /* records rounded up to 2^n */ uint deleted; /* Deleted records in database */ |