Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
a2d7a05f
Commit
a2d7a05f
authored
Mar 28, 2007
by
istruewing@chilla.local
Browse files
Options
Browse Files
Download
Plain Diff
Merge chilla.local:/home/mydev/mysql-4.1-axmrg
into chilla.local:/home/mydev/mysql-5.0-axmrg
parents
7ba1c1b0
db45dc5f
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
364 additions
and
9 deletions
+364
-9
myisam/mi_range.c
myisam/mi_range.c
+35
-1
myisam/mi_search.c
myisam/mi_search.c
+35
-7
mysql-test/r/myisam.result
mysql-test/r/myisam.result
+150
-0
mysql-test/t/heap_btree.test
mysql-test/t/heap_btree.test
+0
-1
mysql-test/t/myisam.test
mysql-test/t/myisam.test
+144
-0
No files found.
myisam/mi_range.c
View file @
a2d7a05f
...
...
@@ -144,8 +144,42 @@ static ha_rows _mi_record_pos(MI_INFO *info, const byte *key, uint key_len,
if
(
!
(
nextflag
&
(
SEARCH_FIND
|
SEARCH_NO_FIND
|
SEARCH_LAST
)))
key_len
=
USE_WHOLE_KEY
;
/*
my_handler.c:mi_compare_text() has a flag 'skip_end_space'.
This is set in my_handler.c:ha_key_cmp() in dependence on the
compare flags 'nextflag' and the column type.
TEXT columns are of type HA_KEYTYPE_VARTEXT. In this case the
condition is skip_end_space= ((nextflag & (SEARCH_FIND |
SEARCH_UPDATE)) == SEARCH_FIND).
SEARCH_FIND is used for an exact key search. The combination
SEARCH_FIND | SEARCH_UPDATE is used in write/update/delete
operations with a comment like "Not real duplicates", whatever this
means. From the condition above we can see that 'skip_end_space' is
always false for these operations. The result is that trailing space
counts in key comparison and hence, emtpy strings ('', string length
zero, but not NULL) compare less that strings starting with control
characters and these in turn compare less than strings starting with
blanks.
When estimating the number of records in a key range, we request an
exact search for the minimum key. This translates into a plain
SEARCH_FIND flag. Using this alone would lead to a 'skip_end_space'
compare. Empty strings would be expected above control characters.
Their keys would not be found because they are located below control
characters.
This is the reason that we add the SEARCH_UPDATE flag here. It makes
the key estimation compare in the same way like key write operations
do. Olny so we will find the keys where they have been inserted.
Adding the flag unconditionally does not hurt as it is used in the
above mentioned condition only. So it can safely be used together
with other flags.
*/
pos
=
_mi_search_pos
(
info
,
keyinfo
,
key_buff
,
key_len
,
nextflag
|
SEARCH_SAVE_BUFF
,
nextflag
|
SEARCH_SAVE_BUFF
|
SEARCH_UPDATE
,
info
->
s
->
state
.
key_root
[
inx
]);
if
(
pos
>=
0
.
0
)
{
...
...
myisam/mi_search.c
View file @
a2d7a05f
...
...
@@ -924,11 +924,16 @@ uint _mi_get_binary_pack_key(register MI_KEYDEF *keyinfo, uint nod_flag,
/*
Keys are compressed the following way:
prefix length Packed length of prefix
for the prev key.
(1 or 3 bytes)
prefix length Packed length of prefix
common with prev key
(1 or 3 bytes)
for each key segment:
[is null] Null indicator if can be null (1 byte, zero means null)
[length] Packed length if varlength (1 or 3 bytes)
key segment 'length' bytes of key segment value
pointer Reference to the data file (last_keyseg->length).
get_key_length() is a macro. It gets the prefix length from 'page'
and puts it into 'length'. It increments 'page' by 1 or 3, depending
on the packed length of the prefix length.
*/
get_key_length
(
length
,
page
);
if
(
length
)
...
...
@@ -942,34 +947,44 @@ uint _mi_get_binary_pack_key(register MI_KEYDEF *keyinfo, uint nod_flag,
my_errno
=
HA_ERR_CRASHED
;
DBUG_RETURN
(
0
);
/* Wrong key */
}
from
=
key
;
from_end
=
key
+
length
;
/* Key is packed against prev key, take prefix from prev key. */
from
=
key
;
from_end
=
key
+
length
;
}
else
{
from
=
page
;
from_end
=
page_end
;
/* Not packed key */
/* Key is not packed against prev key, take all from page buffer. */
from
=
page
;
from_end
=
page_end
;
}
/*
The trouble is that key is split in two parts:
The first part is in from ...from_end-1.
The second part starts at page
The trouble is that key can be split in two parts:
The first part (prefix) is in from .. from_end - 1.
The second part starts at page.
The split can be at every byte position. So we need to check for
the end of the first part before using every byte.
*/
for
(
keyseg
=
keyinfo
->
seg
;
keyseg
->
type
;
keyseg
++
)
{
if
(
keyseg
->
flag
&
HA_NULL_PART
)
{
/* If prefix is used up, switch to rest. */
if
(
from
==
from_end
)
{
from
=
page
;
from_end
=
page_end
;
}
if
(
!
(
*
key
++
=
*
from
++
))
continue
;
/* Null part */
}
if
(
keyseg
->
flag
&
(
HA_VAR_LENGTH_PART
|
HA_BLOB_PART
|
HA_SPACE_PACK
))
{
/*
Get length of dynamic length key part
*/
/*
If prefix is used up, switch to rest.
*/
if
(
from
==
from_end
)
{
from
=
page
;
from_end
=
page_end
;
}
/* Get length of dynamic length key part */
if
((
length
=
(
*
key
++
=
*
from
++
))
==
255
)
{
/* If prefix is used up, switch to rest. */
if
(
from
==
from_end
)
{
from
=
page
;
from_end
=
page_end
;
}
length
=
(
uint
)
((
*
key
++
=
*
from
++
))
<<
8
;
/* If prefix is used up, switch to rest. */
if
(
from
==
from_end
)
{
from
=
page
;
from_end
=
page_end
;
}
length
+=
(
uint
)
((
*
key
++
=
*
from
++
));
}
...
...
@@ -989,14 +1004,26 @@ uint _mi_get_binary_pack_key(register MI_KEYDEF *keyinfo, uint nod_flag,
key
+=
length
;
from
+=
length
;
}
/*
Last segment (type == 0) contains length of data pointer.
If we have mixed key blocks with data pointer and key block pointer,
we have to copy both.
*/
length
=
keyseg
->
length
+
nod_flag
;
if
((
tmp
=
(
uint
)
(
from_end
-
from
))
<=
length
)
{
/* Remaining length is less or equal max possible length. */
memcpy
(
key
+
tmp
,
page
,
length
-
tmp
);
/* Get last part of key */
*
page_pos
=
page
+
length
-
tmp
;
}
else
{
/*
Remaining length is greater than max possible length.
This can happen only if we switched to the new key bytes already.
'page_end' is calculated with MI_MAX_KEY_BUFF. So it can be far
behind the real end of the key.
*/
if
(
from_end
!=
page_end
)
{
DBUG_PRINT
(
"error"
,(
"Error when unpacking key"
));
...
...
@@ -1004,6 +1031,7 @@ uint _mi_get_binary_pack_key(register MI_KEYDEF *keyinfo, uint nod_flag,
my_errno
=
HA_ERR_CRASHED
;
DBUG_RETURN
(
0
);
/* Error */
}
/* Copy data pointer and, if appropriate, key block pointer. */
memcpy
((
byte
*
)
key
,(
byte
*
)
from
,(
size_t
)
length
);
*
page_pos
=
from
+
length
;
}
...
...
mysql-test/r/myisam.result
View file @
a2d7a05f
...
...
@@ -943,6 +943,156 @@ SHOW TABLE STATUS LIKE 't1';
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment
t1 MyISAM 10 Dynamic X X X 72057594037927935 X X X X X X latin1_swedish_ci X max_rows=4100100100 avg_row_length=70100
DROP TABLE t1;
CREATE TABLE t1 (c1 TEXT NOT NULL, KEY c1 (c1(10))) ENGINE=MyISAM;
INSERT INTO t1 VALUES
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(CHAR(9,65)),
(CHAR(9,65)), (CHAR(9,65)), (CHAR(9,65)),
(''),
(''), (''), (''),
('
B'), (' B'), (' B'), (' B');
SELECT DISTINCT COUNT(*) FROM t1 WHERE c1 = '';
COUNT(*)
4
SELECT DISTINCT length(c1), c1 FROM t1 WHERE c1 = '';
length(c1) c1
0
SELECT DISTINCT COUNT(*) FROM t1 IGNORE INDEX (c1) WHERE c1 = '';
COUNT(*)
4
SELECT DISTINCT length(c1), c1 FROM t1 IGNORE INDEX (c1) WHERE c1 = '';
length(c1) c1
0
SELECT DISTINCT length(c1), c1 FROM t1 ORDER BY c1;
length(c1) c1
0
2 A
2 B
DROP TABLE t1;
End of 4.1 tests
set storage_engine=MyISAM;
drop table if exists t1,t2,t3;
...
...
mysql-test/t/heap_btree.test
View file @
a2d7a05f
...
...
@@ -235,4 +235,3 @@ CREATE TABLE t1 (a INT, UNIQUE USING BTREE(a)) ENGINE=MEMORY;
INSERT
INTO
t1
VALUES
(
NULL
),(
NULL
);
DROP
TABLE
t1
;
--
echo
End
of
5.0
tests
mysql-test/t/myisam.test
View file @
a2d7a05f
...
...
@@ -874,6 +874,150 @@ CREATE TABLE t1 (c1 TEXT) AVG_ROW_LENGTH=70100 MAX_ROWS=4100100100;
SHOW
TABLE
STATUS
LIKE
't1'
;
DROP
TABLE
t1
;
#
# Bug#26231 - select count(*) on myisam table returns wrong value
# when index is used
#
CREATE
TABLE
t1
(
c1
TEXT
NOT
NULL
,
KEY
c1
(
c1
(
10
)))
ENGINE
=
MyISAM
;
# Fill at least two key blocks. "Tab, A" must be in both blocks.
INSERT
INTO
t1
VALUES
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
CHAR
(
9
,
65
)),
(
''
),
(
''
),
(
''
),
(
''
),
(
' B'
),
(
' B'
),
(
' B'
),
(
' B'
);
SELECT
DISTINCT
COUNT
(
*
)
FROM
t1
WHERE
c1
=
''
;
SELECT
DISTINCT
length
(
c1
),
c1
FROM
t1
WHERE
c1
=
''
;
SELECT
DISTINCT
COUNT
(
*
)
FROM
t1
IGNORE
INDEX
(
c1
)
WHERE
c1
=
''
;
SELECT
DISTINCT
length
(
c1
),
c1
FROM
t1
IGNORE
INDEX
(
c1
)
WHERE
c1
=
''
;
SELECT
DISTINCT
length
(
c1
),
c1
FROM
t1
ORDER
BY
c1
;
DROP
TABLE
t1
;
--
echo
End
of
4.1
tests
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment