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
afac13d0
Commit
afac13d0
authored
Oct 08, 2003
by
bell@laptop.sanja.is.com.ua
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Some simple optimisation
= ANY and <> ALL converted to (NOT) IN to get advantage of IN optimisation
parent
381b6808
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
69 additions
and
18 deletions
+69
-18
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+18
-0
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+4
-0
sql/mysql_priv.h
sql/mysql_priv.h
+5
-0
sql/sql_parse.cc
sql/sql_parse.cc
+39
-0
sql/sql_yacc.yy
sql/sql_yacc.yy
+3
-18
No files found.
mysql-test/r/subselect.result
View file @
afac13d0
...
@@ -1403,6 +1403,16 @@ s1 s1 NOT IN (SELECT s1 FROM t2)
...
@@ -1403,6 +1403,16 @@ s1 s1 NOT IN (SELECT s1 FROM t2)
a1 0
a1 0
a2 0
a2 0
a3 1
a3 1
select s1, s1 = ANY (SELECT s1 FROM t2) from t1;
s1 s1 = ANY (SELECT s1 FROM t2)
a1 1
a2 1
a3 0
select s1, s1 <> ALL (SELECT s1 FROM t2) from t1;
s1 s1 <> ALL (SELECT s1 FROM t2)
a1 0
a2 0
a3 1
select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
s1 s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2')
s1 s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2')
a1 0
a1 0
...
@@ -1412,6 +1422,14 @@ explain select s1, s1 NOT IN (SELECT s1 FROM t2) from t1;
...
@@ -1412,6 +1422,14 @@ explain select s1, s1 NOT IN (SELECT s1 FROM t2) from t1;
id select_type table type possible_keys key key_len ref rows Extra
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
explain select s1, s1 = ANY (SELECT s1 FROM t2) from t1;
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
explain select s1, s1 <> ALL (SELECT s1 FROM t2) from t1;
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
2 DEPENDENT SUBQUERY t2 index_subquery s1 s1 6 func 2 Using index
explain select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
explain select s1, s1 NOT IN (SELECT s1 FROM t2 WHERE s1 < 'a2') from t1;
id select_type table type possible_keys key key_len ref rows Extra
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
1 PRIMARY t1 index NULL s1 6 NULL 3 Using index
...
...
mysql-test/t/subselect.test
View file @
afac13d0
...
@@ -947,8 +947,12 @@ create table t2 (s1 char(5), index s1(s1));
...
@@ -947,8 +947,12 @@ create table t2 (s1 char(5), index s1(s1));
insert
into
t1
values
(
'a1'
),(
'a2'
),(
'a3'
);
insert
into
t1
values
(
'a1'
),(
'a2'
),(
'a3'
);
insert
into
t2
values
(
'a1'
),(
'a2'
);
insert
into
t2
values
(
'a1'
),(
'a2'
);
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
)
from
t1
;
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
)
from
t1
;
select
s1
,
s1
=
ANY
(
SELECT
s1
FROM
t2
)
from
t1
;
select
s1
,
s1
<>
ALL
(
SELECT
s1
FROM
t2
)
from
t1
;
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
WHERE
s1
<
'a2'
)
from
t1
;
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
WHERE
s1
<
'a2'
)
from
t1
;
explain
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
)
from
t1
;
explain
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
)
from
t1
;
explain
select
s1
,
s1
=
ANY
(
SELECT
s1
FROM
t2
)
from
t1
;
explain
select
s1
,
s1
<>
ALL
(
SELECT
s1
FROM
t2
)
from
t1
;
explain
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
WHERE
s1
<
'a2'
)
from
t1
;
explain
select
s1
,
s1
NOT
IN
(
SELECT
s1
FROM
t2
WHERE
s1
<
'a2'
)
from
t1
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
...
...
sql/mysql_priv.h
View file @
afac13d0
...
@@ -1015,6 +1015,11 @@ compare_func_creator comp_le_creator(bool invert);
...
@@ -1015,6 +1015,11 @@ compare_func_creator comp_le_creator(bool invert);
compare_func_creator
comp_lt_creator
(
bool
invert
);
compare_func_creator
comp_lt_creator
(
bool
invert
);
compare_func_creator
comp_ne_creator
(
bool
invert
);
compare_func_creator
comp_ne_creator
(
bool
invert
);
Item
*
all_any_subquery_creator
(
Item
*
left_expr
,
chooser_compare_func_creator
cmp
,
bool
all
,
SELECT_LEX
*
select_lex
);
/*
/*
clean/setup table fields and map
clean/setup table fields and map
...
...
sql/sql_parse.cc
View file @
afac13d0
...
@@ -4610,32 +4610,71 @@ bool check_simple_select()
...
@@ -4610,32 +4610,71 @@ bool check_simple_select()
return
0
;
return
0
;
}
}
compare_func_creator
comp_eq_creator
(
bool
invert
)
compare_func_creator
comp_eq_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
ne_creator
:&
Item_bool_func2
::
eq_creator
;
return
invert
?&
Item_bool_func2
::
ne_creator
:&
Item_bool_func2
::
eq_creator
;
}
}
compare_func_creator
comp_ge_creator
(
bool
invert
)
compare_func_creator
comp_ge_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
lt_creator
:&
Item_bool_func2
::
ge_creator
;
return
invert
?&
Item_bool_func2
::
lt_creator
:&
Item_bool_func2
::
ge_creator
;
}
}
compare_func_creator
comp_gt_creator
(
bool
invert
)
compare_func_creator
comp_gt_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
le_creator
:&
Item_bool_func2
::
gt_creator
;
return
invert
?&
Item_bool_func2
::
le_creator
:&
Item_bool_func2
::
gt_creator
;
}
}
compare_func_creator
comp_le_creator
(
bool
invert
)
compare_func_creator
comp_le_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
gt_creator
:&
Item_bool_func2
::
le_creator
;
return
invert
?&
Item_bool_func2
::
gt_creator
:&
Item_bool_func2
::
le_creator
;
}
}
compare_func_creator
comp_lt_creator
(
bool
invert
)
compare_func_creator
comp_lt_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
ge_creator
:&
Item_bool_func2
::
lt_creator
;
return
invert
?&
Item_bool_func2
::
ge_creator
:&
Item_bool_func2
::
lt_creator
;
}
}
compare_func_creator
comp_ne_creator
(
bool
invert
)
compare_func_creator
comp_ne_creator
(
bool
invert
)
{
{
return
invert
?&
Item_bool_func2
::
eq_creator
:&
Item_bool_func2
::
ne_creator
;
return
invert
?&
Item_bool_func2
::
eq_creator
:&
Item_bool_func2
::
ne_creator
;
}
}
/*
Construct ALL/ANY/SOME subquery Item
SYNOPSIS
all_any_subquery_creator()
left_expr - pointer to left expression
cmp - compare function creator
all - true if we create ALL subquery
select_lex - pointer on parsed subquery structure
RETURN VALUE
constructed Item (or 0 if out of memory)
*/
Item
*
all_any_subquery_creator
(
Item
*
left_expr
,
chooser_compare_func_creator
cmp
,
bool
all
,
SELECT_LEX
*
select_lex
)
{
if
((
cmp
==
&
comp_eq_creator
)
and
!
all
)
// = ANY <=> IN
return
new
Item_in_subselect
(
left_expr
,
select_lex
);
if
((
cmp
==
&
comp_ne_creator
)
and
all
)
// <> ALL <=> NOT IN
return
new
Item_func_not
(
new
Item_in_subselect
(
left_expr
,
select_lex
));
Item_allany_subselect
*
it
=
new
Item_allany_subselect
(
left_expr
,
(
*
cmp
)(
all
),
select_lex
);
if
(
all
)
return
it
->
upper_not
=
new
Item_func_not_all
(
it
);
/* ALL */
return
it
;
/* ANY/SOME */
}
sql/sql_yacc.yy
View file @
afac13d0
...
@@ -2262,12 +2262,7 @@ expr_expr:
...
@@ -2262,12 +2262,7 @@ expr_expr:
| expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| expr comp_op all_or_any in_subselect %prec EQ
| expr comp_op all_or_any in_subselect %prec EQ
{
{
Item_allany_subselect *it=
$$= all_any_subquery_creator($1, $2, $3, $4);
new Item_allany_subselect($1, (*$2)($3), $4);
if ($3)
$$ = it->upper_not= new Item_func_not_all(it); /* ALL */
else
$$ = it; /* ANY/SOME */
}
}
| expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
| expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
...
@@ -2308,12 +2303,7 @@ no_in_expr:
...
@@ -2308,12 +2303,7 @@ no_in_expr:
| no_in_expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| no_in_expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| no_in_expr comp_op all_or_any in_subselect %prec EQ
| no_in_expr comp_op all_or_any in_subselect %prec EQ
{
{
Item_allany_subselect *it=
all_any_subquery_creator($1, $2, $3, $4);
new Item_allany_subselect($1, (*$2)($3), $4);
if ($3)
$$ = it->upper_not= new Item_func_not_all(it); /* ALL */
else
$$ = it; /* ANY/SOME */
}
}
| no_in_expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| no_in_expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| no_in_expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
| no_in_expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
...
@@ -2363,12 +2353,7 @@ no_and_expr:
...
@@ -2363,12 +2353,7 @@ no_and_expr:
| no_and_expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| no_and_expr comp_op expr %prec EQ { $$= (*((*$2)(0)))($1,$3); }
| no_and_expr comp_op all_or_any in_subselect %prec EQ
| no_and_expr comp_op all_or_any in_subselect %prec EQ
{
{
Item_allany_subselect *it=
all_any_subquery_creator($1, $2, $3, $4);
new Item_allany_subselect($1, (*$2)($3), $4);
if ($3)
$$ = it->upper_not= new Item_func_not_all(it); /* ALL */
else
$$ = it; /* ANY/SOME */
}
}
| no_and_expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| no_and_expr SHIFT_LEFT expr { $$= new Item_func_shift_left($1,$3); }
| no_and_expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
| no_and_expr SHIFT_RIGHT expr { $$= new Item_func_shift_right($1,$3); }
...
...
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