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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
d07df8f6
Commit
d07df8f6
authored
Apr 21, 2007
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge spetrunia@bk-internal.mysql.com:/home/bk/mysql-5.0-opt
into mysql.com:/home/psergey/mysql-5.0-bug27939
parents
69ed5e93
60d2ec9e
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
54 additions
and
2 deletions
+54
-2
mysql-test/r/join.result
mysql-test/r/join.result
+28
-0
mysql-test/t/join.test
mysql-test/t/join.test
+23
-0
sql/sql_select.cc
sql/sql_select.cc
+3
-2
No files found.
mysql-test/r/join.result
View file @
d07df8f6
...
@@ -779,4 +779,32 @@ Field Type Null Key Default Extra
...
@@ -779,4 +779,32 @@ Field Type Null Key Default Extra
Name varchar(50) YES NULL
Name varchar(50) YES NULL
DROP VIEW v1;
DROP VIEW v1;
DROP TABLE t1,t2,tv1,tv2;
DROP TABLE t1,t2,tv1,tv2;
create table t1 (a int, b int);
insert into t1 values
(NULL, 1),
(NULL, 2),
(NULL, 3),
(NULL, 4);
create table t2 (a int not null, primary key(a));
insert into t2 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
create table t3 (a int not null, primary key(a));
insert into t3 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
flush status;
select * from t1, t2, t3 where t3.a=t1.a and t2.a=t1.b;
a b a a
explain select * from t1, t2, t3 where t3.a=t1.a and t2.a=t1.b;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 ALL NULL NULL NULL NULL 4
1 SIMPLE t2 eq_ref PRIMARY PRIMARY 4 test.t1.b 1 Using index
1 SIMPLE t3 eq_ref PRIMARY PRIMARY 4 test.t1.a 1 Using index
We expect rnd_next=5, and read_key must be 0 because of short-cutting:
show status like 'Handler_read%';
Variable_name Value
Handler_read_first 0
Handler_read_key 0
Handler_read_next 0
Handler_read_prev 0
Handler_read_rnd 0
Handler_read_rnd_next 5
drop table t1, t2, t3;
End of 5.0 tests.
End of 5.0 tests.
mysql-test/t/join.test
View file @
d07df8f6
...
@@ -610,4 +610,27 @@ DESCRIBE tv2;
...
@@ -610,4 +610,27 @@ DESCRIBE tv2;
DROP
VIEW
v1
;
DROP
VIEW
v1
;
DROP
TABLE
t1
,
t2
,
tv1
,
tv2
;
DROP
TABLE
t1
,
t2
,
tv1
,
tv2
;
# BUG#27939: Early NULLs filtering doesn't work for eq_ref access
create
table
t1
(
a
int
,
b
int
);
insert
into
t1
values
(
NULL
,
1
),
(
NULL
,
2
),
(
NULL
,
3
),
(
NULL
,
4
);
create
table
t2
(
a
int
not
null
,
primary
key
(
a
));
insert
into
t2
values
(
0
),(
1
),(
2
),(
3
),(
4
),(
5
),(
6
),(
7
),(
8
),(
9
);
create
table
t3
(
a
int
not
null
,
primary
key
(
a
));
insert
into
t3
values
(
0
),(
1
),(
2
),(
3
),(
4
),(
5
),(
6
),(
7
),(
8
),(
9
);
flush
status
;
select
*
from
t1
,
t2
,
t3
where
t3
.
a
=
t1
.
a
and
t2
.
a
=
t1
.
b
;
explain
select
*
from
t1
,
t2
,
t3
where
t3
.
a
=
t1
.
a
and
t2
.
a
=
t1
.
b
;
--
echo
We
expect
rnd_next
=
5
,
and
read_key
must
be
0
because
of
short
-
cutting
:
show
status
like
'Handler_read%'
;
drop
table
t1
,
t2
,
t3
;
--
echo
End
of
5.0
tests
.
--
echo
End
of
5.0
tests
.
sql/sql_select.cc
View file @
d07df8f6
...
@@ -5444,8 +5444,9 @@ static void add_not_null_conds(JOIN *join)
...
@@ -5444,8 +5444,9 @@ static void add_not_null_conds(JOIN *join)
for
(
uint
i
=
join
->
const_tables
;
i
<
join
->
tables
;
i
++
)
for
(
uint
i
=
join
->
const_tables
;
i
<
join
->
tables
;
i
++
)
{
{
JOIN_TAB
*
tab
=
join
->
join_tab
+
i
;
JOIN_TAB
*
tab
=
join
->
join_tab
+
i
;
if
((
tab
->
type
==
JT_REF
||
tab
->
type
==
JT_REF_OR_NULL
)
&&
if
((
tab
->
type
==
JT_REF
||
tab
->
type
==
JT_EQ_REF
||
!
tab
->
table
->
maybe_null
)
tab
->
type
==
JT_REF_OR_NULL
)
&&
!
tab
->
table
->
maybe_null
)
{
{
for
(
uint
keypart
=
0
;
keypart
<
tab
->
ref
.
key_parts
;
keypart
++
)
for
(
uint
keypart
=
0
;
keypart
<
tab
->
ref
.
key_parts
;
keypart
++
)
{
{
...
...
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