summaryrefslogtreecommitdiff
path: root/sql/sql_select.cc
diff options
context:
space:
mode:
authorramil/ram@mysql.com/myoffice.izhnet.ru <>2006-10-19 12:52:37 +0500
committerramil/ram@mysql.com/myoffice.izhnet.ru <>2006-10-19 12:52:37 +0500
commit0027b6e4b772a6b90ed67048451f3455aacfbf5d (patch)
tree46f10dec22a47aca4f01060db36cdfc4d2465f82 /sql/sql_select.cc
parentcfd442b67f8b13ebfc665d2c63436319c360870a (diff)
downloadmariadb-git-0027b6e4b772a6b90ed67048451f3455aacfbf5d.tar.gz
Fix for bug #20732: Partial index and long sjis search with '>' fails sometimes
We miss some records sometimes using RANGE method if we have partial key segments. Example: Create table t1(a char(2), key(a(1))); insert into t1 values ('a'), ('xx'); select a from t1 where a > 'x'; We call index_read() passing 'x' key and HA_READ_AFTER_KEY flag in the handler::read_range_first() wich is wrong because we have a partial key segment for the field and might miss records like 'xx'. Fix: don't use open segments in such a case.
Diffstat (limited to 'sql/sql_select.cc')
-rw-r--r--sql/sql_select.cc2
1 files changed, 1 insertions, 1 deletions
diff --git a/sql/sql_select.cc b/sql/sql_select.cc
index 33e923e1553..009cd7ae283 100644
--- a/sql/sql_select.cc
+++ b/sql/sql_select.cc
@@ -7337,7 +7337,7 @@ part_of_refkey(TABLE *table,Field *field)
for (uint part=0 ; part < ref_parts ; part++,key_part++)
if (field->eq(key_part->field) &&
- !(key_part->key_part_flag & HA_PART_KEY_SEG))
+ !(key_part->key_part_flag & (HA_PART_KEY_SEG | HA_NULL_PART)))
return table->reginfo.join_tab->ref.items[part];
}
return (Item*) 0;