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
b2185606
Commit
b2185606
authored
Dec 07, 2004
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
merge
parents
f30049f4
f5e253dc
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
229 additions
and
26 deletions
+229
-26
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+75
-1
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+23
-1
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+39
-7
sql/item_cmpfunc.h
sql/item_cmpfunc.h
+23
-1
sql/item_subselect.cc
sql/item_subselect.cc
+28
-7
sql/item_subselect.h
sql/item_subselect.h
+16
-4
sql/item_sum.cc
sql/item_sum.cc
+13
-0
sql/item_sum.h
sql/item_sum.h
+6
-2
sql/sql_class.cc
sql/sql_class.cc
+2
-1
sql/sql_parse.cc
sql/sql_parse.cc
+2
-2
sql/sql_union.cc
sql/sql_union.cc
+2
-0
No files found.
mysql-test/r/subselect.result
View file @
b2185606
...
@@ -269,7 +269,7 @@ id select_type table type possible_keys key key_len ref rows Extra
...
@@ -269,7 +269,7 @@ id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t3 ALL NULL NULL NULL NULL 3 Using where
1 PRIMARY t3 ALL NULL NULL NULL NULL 3 Using where
2 SUBQUERY t2 ALL NULL NULL NULL NULL 3
2 SUBQUERY t2 ALL NULL NULL NULL NULL 3
Warnings:
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3 where
(test.t3.a >= (select min(test.t2.b) from test.t2
))
Note 1003 select test.t3.a AS `a` from test.t3 where
<nop>((test.t3.a >= (select min(test.t2.b) from test.t2)
))
select * from t3 where a >= all (select b from t2);
select * from t3 where a >= all (select b from t2);
a
a
7
7
...
@@ -1488,6 +1488,71 @@ id select_type table type possible_keys key key_len ref rows Extra
...
@@ -1488,6 +1488,71 @@ id select_type table type possible_keys key key_len ref rows Extra
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3 where <not>((test.t3.a < (select max(test.t2.b) from test.t2)))
Note 1003 select test.t3.a AS `a` from test.t3 where <not>((test.t3.a < (select max(test.t2.b) from test.t2)))
select * from t3 where a >= some (select b from t2);
a
6
7
3
explain extended select * from t3 where a >= some (select b from t2);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t3 ALL NULL NULL NULL NULL 3 Using where
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3 where <nop>((test.t3.a >= (select min(test.t2.b) from test.t2)))
select * from t3 where a >= all (select b from t2 group by 1);
a
6
7
3
explain extended select * from t3 where a >= all (select b from t2 group by 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t3 ALL NULL NULL NULL NULL 3 Using where
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3 where <not>((test.t3.a < <max>(select test.t2.b AS `b` from test.t2 group by test.t2.b)))
select * from t3 where a >= some (select b from t2 group by 1);
a
6
7
3
explain extended select * from t3 where a >= some (select b from t2 group by 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY t3 ALL NULL NULL NULL NULL 3 Using where
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3 where <nop>((test.t3.a >= <min>(select test.t2.b AS `b` from test.t2 group by test.t2.b)))
select * from t3 where NULL >= any (select b from t2);
a
explain extended select * from t3 where NULL >= any (select b from t2);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3
select * from t3 where NULL >= any (select b from t2 group by 1);
a
explain extended select * from t3 where NULL >= any (select b from t2 group by 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3
select * from t3 where NULL >= some (select b from t2);
a
explain extended select * from t3 where NULL >= some (select b from t2);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3
select * from t3 where NULL >= some (select b from t2 group by 1);
a
explain extended select * from t3 where NULL >= some (select b from t2 group by 1);
id select_type table type possible_keys key key_len ref rows Extra
1 PRIMARY NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
2 SUBQUERY t2 system NULL NULL NULL NULL 0 const row not found
Warnings:
Note 1003 select test.t3.a AS `a` from test.t3
insert into t2 values (2,2), (2,1), (3,3), (3,1);
insert into t2 values (2,2), (2,1), (3,3), (3,1);
select * from t3 where a > all (select max(b) from t2 group by a);
select * from t3 where a > all (select max(b) from t2 group by a);
a
a
...
@@ -2031,3 +2096,12 @@ insert into t1 values (20,15);
...
@@ -2031,3 +2096,12 @@ insert into t1 values (20,15);
select * from t1 where (('a',null) <=> (select 'a',s2 from t1 where s1 = 0));
select * from t1 where (('a',null) <=> (select 'a',s2 from t1 where s1 = 0));
s1 s2
s1 s2
drop table t1;
drop table t1;
create table t1 (s1 int);
insert into t1 values (1),(null);
select * from t1 where s1 < all (select s1 from t1);
s1
select s1, s1 < all (select s1 from t1) from t1;
s1 s1 < all (select s1 from t1)
1 0
NULL NULL
drop table t1;
mysql-test/t/subselect.test
View file @
b2185606
...
@@ -911,7 +911,20 @@ create table t3 (a int);
...
@@ -911,7 +911,20 @@ create table t3 (a int);
insert
into
t3
values
(
6
),(
7
),(
3
);
insert
into
t3
values
(
6
),(
7
),(
3
);
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
);
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
);
explain
extended
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
);
explain
extended
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
);
select
*
from
t3
where
a
>=
some
(
select
b
from
t2
);
explain
extended
select
*
from
t3
where
a
>=
some
(
select
b
from
t2
);
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
group
by
1
);
explain
extended
select
*
from
t3
where
a
>=
all
(
select
b
from
t2
group
by
1
);
select
*
from
t3
where
a
>=
some
(
select
b
from
t2
group
by
1
);
explain
extended
select
*
from
t3
where
a
>=
some
(
select
b
from
t2
group
by
1
);
select
*
from
t3
where
NULL
>=
any
(
select
b
from
t2
);
explain
extended
select
*
from
t3
where
NULL
>=
any
(
select
b
from
t2
);
select
*
from
t3
where
NULL
>=
any
(
select
b
from
t2
group
by
1
);
explain
extended
select
*
from
t3
where
NULL
>=
any
(
select
b
from
t2
group
by
1
);
select
*
from
t3
where
NULL
>=
some
(
select
b
from
t2
);
explain
extended
select
*
from
t3
where
NULL
>=
some
(
select
b
from
t2
);
select
*
from
t3
where
NULL
>=
some
(
select
b
from
t2
group
by
1
);
explain
extended
select
*
from
t3
where
NULL
>=
some
(
select
b
from
t2
group
by
1
);
#
#
# optimized static ALL/ANY with grouping
# optimized static ALL/ANY with grouping
#
#
...
@@ -1336,3 +1349,12 @@ create table t1 (s1 int,s2 int);
...
@@ -1336,3 +1349,12 @@ create table t1 (s1 int,s2 int);
insert
into
t1
values
(
20
,
15
);
insert
into
t1
values
(
20
,
15
);
select
*
from
t1
where
((
'a'
,
null
)
<=>
(
select
'a'
,
s2
from
t1
where
s1
=
0
));
select
*
from
t1
where
((
'a'
,
null
)
<=>
(
select
'a'
,
s2
from
t1
where
s1
=
0
));
drop
table
t1
;
drop
table
t1
;
#
# ALL/ANY with NULL
#
create
table
t1
(
s1
int
);
insert
into
t1
values
(
1
),(
null
);
select
*
from
t1
where
s1
<
all
(
select
s1
from
t1
);
select
s1
,
s1
<
all
(
select
s1
from
t1
)
from
t1
;
drop
table
t1
;
sql/item_cmpfunc.cc
View file @
b2185606
...
@@ -106,7 +106,7 @@ longlong Item_func_not::val_int()
...
@@ -106,7 +106,7 @@ longlong Item_func_not::val_int()
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
double
value
=
args
[
0
]
->
val
();
double
value
=
args
[
0
]
->
val
();
null_value
=
args
[
0
]
->
null_value
;
null_value
=
args
[
0
]
->
null_value
;
return
!
null_value
&&
value
==
0
?
1
:
0
;
return
((
!
null_value
&&
value
==
0
)
?
1
:
0
)
;
}
}
/*
/*
...
@@ -117,13 +117,23 @@ longlong Item_func_not_all::val_int()
...
@@ -117,13 +117,23 @@ longlong Item_func_not_all::val_int()
{
{
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
double
value
=
args
[
0
]
->
val
();
double
value
=
args
[
0
]
->
val
();
if
(
abort_on_null
)
{
/*
null_value
=
0
;
return TRUE if there was records in underlaying select in max/min
return
(
args
[
0
]
->
null_value
||
value
==
0
)
?
1
:
0
;
optimisation
}
*/
if
(
empty_underlying_subquery
())
return
1
;
null_value
=
args
[
0
]
->
null_value
;
null_value
=
args
[
0
]
->
null_value
;
return
(
!
null_value
&&
value
==
0
)
?
1
:
0
;
return
((
!
null_value
&&
value
==
0
)
?
1
:
0
);
}
bool
Item_func_not_all
::
empty_underlying_subquery
()
{
return
((
test_sum_item
&&
!
test_sum_item
->
any_value
())
||
(
test_sub_item
&&
!
test_sub_item
->
any_value
()));
}
}
void
Item_func_not_all
::
print
(
String
*
str
)
void
Item_func_not_all
::
print
(
String
*
str
)
...
@@ -134,6 +144,28 @@ void Item_func_not_all::print(String *str)
...
@@ -134,6 +144,28 @@ void Item_func_not_all::print(String *str)
args
[
0
]
->
print
(
str
);
args
[
0
]
->
print
(
str
);
}
}
/*
special NOP for ALL subquery
*/
longlong
Item_func_nop_all
::
val_int
()
{
DBUG_ASSERT
(
fixed
==
1
);
double
value
=
args
[
0
]
->
val
();
/*
return TRUE if there was records in underlaying select in max/min
optimisation
*/
if
(
empty_underlying_subquery
())
return
1
;
null_value
=
args
[
0
]
->
null_value
;
return
(
null_value
||
value
==
0
)
?
0
:
1
;
}
/*
/*
Convert a constant expression or string to an integer.
Convert a constant expression or string to an integer.
This is done when comparing DATE's of different formats and
This is done when comparing DATE's of different formats and
...
...
sql/item_cmpfunc.h
View file @
b2185606
...
@@ -229,21 +229,43 @@ class Item_func_not :public Item_bool_func
...
@@ -229,21 +229,43 @@ class Item_func_not :public Item_bool_func
Item
*
neg_transformer
(
THD
*
thd
);
Item
*
neg_transformer
(
THD
*
thd
);
};
};
class
Item_maxmin_subselect
;
class
Item_func_not_all
:
public
Item_func_not
class
Item_func_not_all
:
public
Item_func_not
{
{
/* allow to check presence od values in max/min optimisation */
Item_sum_hybrid
*
test_sum_item
;
Item_maxmin_subselect
*
test_sub_item
;
bool
abort_on_null
;
bool
abort_on_null
;
public:
public:
bool
show
;
bool
show
;
Item_func_not_all
(
Item
*
a
)
:
Item_func_not
(
a
),
abort_on_null
(
0
),
show
(
0
)
{}
Item_func_not_all
(
Item
*
a
)
:
Item_func_not
(
a
),
test_sum_item
(
0
),
test_sub_item
(
0
),
abort_on_null
(
0
),
show
(
0
)
{}
virtual
void
top_level_item
()
{
abort_on_null
=
1
;
}
virtual
void
top_level_item
()
{
abort_on_null
=
1
;
}
bool
top_level
()
{
return
abort_on_null
;
}
bool
top_level
()
{
return
abort_on_null
;
}
longlong
val_int
();
longlong
val_int
();
enum
Functype
functype
()
const
{
return
NOT_ALL_FUNC
;
}
enum
Functype
functype
()
const
{
return
NOT_ALL_FUNC
;
}
const
char
*
func_name
()
const
{
return
"<not>"
;
}
const
char
*
func_name
()
const
{
return
"<not>"
;
}
void
print
(
String
*
str
);
void
print
(
String
*
str
);
void
set_sum_test
(
Item_sum_hybrid
*
item
)
{
test_sum_item
=
item
;
};
void
set_sub_test
(
Item_maxmin_subselect
*
item
)
{
test_sub_item
=
item
;
};
bool
empty_underlying_subquery
();
};
class
Item_func_nop_all
:
public
Item_func_not_all
{
public:
Item_func_nop_all
(
Item
*
a
)
:
Item_func_not_all
(
a
)
{}
longlong
val_int
();
const
char
*
func_name
()
const
{
return
"<nop>"
;
}
};
};
class
Item_func_eq
:
public
Item_bool_rowready_func2
class
Item_func_eq
:
public
Item_bool_rowready_func2
{
{
public:
public:
...
...
sql/item_subselect.cc
View file @
b2185606
...
@@ -271,7 +271,7 @@ Item_singlerow_subselect::Item_singlerow_subselect(st_select_lex *select_lex)
...
@@ -271,7 +271,7 @@ Item_singlerow_subselect::Item_singlerow_subselect(st_select_lex *select_lex)
Item_maxmin_subselect
::
Item_maxmin_subselect
(
Item_subselect
*
parent
,
Item_maxmin_subselect
::
Item_maxmin_subselect
(
Item_subselect
*
parent
,
st_select_lex
*
select_lex
,
st_select_lex
*
select_lex
,
bool
max_arg
)
bool
max_arg
)
:
Item_singlerow_subselect
()
:
Item_singlerow_subselect
()
,
was_values
(
TRUE
)
{
{
DBUG_ENTER
(
"Item_maxmin_subselect::Item_maxmin_subselect"
);
DBUG_ENTER
(
"Item_maxmin_subselect::Item_maxmin_subselect"
);
max
=
max_arg
;
max
=
max_arg
;
...
@@ -290,12 +290,26 @@ Item_maxmin_subselect::Item_maxmin_subselect(Item_subselect *parent,
...
@@ -290,12 +290,26 @@ Item_maxmin_subselect::Item_maxmin_subselect(Item_subselect *parent,
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_maxmin_subselect
::
cleanup
()
{
/*
By default is is TRUE to avoid TRUE reporting by
Item_func_not_all/Item_func_nop_all if this item was never called.
Engine exec() set it to FALSE by reset_value_registration() call.
*/
was_values
=
TRUE
;
}
void
Item_maxmin_subselect
::
print
(
String
*
str
)
void
Item_maxmin_subselect
::
print
(
String
*
str
)
{
{
str
->
append
(
max
?
"<max>"
:
"<min>"
,
5
);
str
->
append
(
max
?
"<max>"
:
"<min>"
,
5
);
Item_singlerow_subselect
::
print
(
str
);
Item_singlerow_subselect
::
print
(
str
);
}
}
void
Item_singlerow_subselect
::
reset
()
void
Item_singlerow_subselect
::
reset
()
{
{
null_value
=
1
;
null_value
=
1
;
...
@@ -303,6 +317,7 @@ void Item_singlerow_subselect::reset()
...
@@ -303,6 +317,7 @@ void Item_singlerow_subselect::reset()
value
->
null_value
=
1
;
value
->
null_value
=
1
;
}
}
Item_subselect
::
trans_res
Item_subselect
::
trans_res
Item_singlerow_subselect
::
select_transformer
(
JOIN
*
join
)
Item_singlerow_subselect
::
select_transformer
(
JOIN
*
join
)
{
{
...
@@ -519,7 +534,7 @@ bool Item_in_subselect::test_limit(SELECT_LEX_UNIT *unit)
...
@@ -519,7 +534,7 @@ bool Item_in_subselect::test_limit(SELECT_LEX_UNIT *unit)
Item_in_subselect
::
Item_in_subselect
(
Item
*
left_exp
,
Item_in_subselect
::
Item_in_subselect
(
Item
*
left_exp
,
st_select_lex
*
select_lex
)
:
st_select_lex
*
select_lex
)
:
Item_exists_subselect
(),
transformed
(
0
),
upper_
not
(
0
)
Item_exists_subselect
(),
transformed
(
0
),
upper_
item
(
0
)
{
{
DBUG_ENTER
(
"Item_in_subselect::Item_in_subselect"
);
DBUG_ENTER
(
"Item_in_subselect::Item_in_subselect"
);
left_expr
=
left_exp
;
left_expr
=
left_exp
;
...
@@ -680,7 +695,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -680,7 +695,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
NULL/IS NOT NULL functions). If so, we rewrite ALL/ANY with NOT EXISTS
NULL/IS NOT NULL functions). If so, we rewrite ALL/ANY with NOT EXISTS
later in this method.
later in this method.
*/
*/
if
((
abort_on_null
||
(
upper_
not
&&
upper_not
->
top_level
()))
&&
if
((
abort_on_null
||
(
upper_
item
&&
upper_item
->
top_level
()))
&&
!
select_lex
->
master_unit
()
->
uncacheable
&&
!
func
->
eqne_op
())
!
select_lex
->
master_unit
()
->
uncacheable
&&
!
func
->
eqne_op
())
{
{
if
(
substitution
)
if
(
substitution
)
...
@@ -694,7 +709,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -694,7 +709,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
!
select_lex
->
with_sum_func
&&
!
select_lex
->
with_sum_func
&&
!
(
select_lex
->
next_select
()))
!
(
select_lex
->
next_select
()))
{
{
Item
*
item
;
Item
_sum_hybrid
*
item
;
if
(
func
->
l_op
())
if
(
func
->
l_op
())
{
{
/*
/*
...
@@ -711,6 +726,8 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -711,6 +726,8 @@ Item_in_subselect::single_value_transformer(JOIN *join,
*/
*/
item
=
new
Item_sum_min
(
*
select_lex
->
ref_pointer_array
);
item
=
new
Item_sum_min
(
*
select_lex
->
ref_pointer_array
);
}
}
if
(
upper_item
)
upper_item
->
set_sum_test
(
item
);
*
select_lex
->
ref_pointer_array
=
item
;
*
select_lex
->
ref_pointer_array
=
item
;
{
{
List_iterator
<
Item
>
it
(
select_lex
->
item_list
);
List_iterator
<
Item
>
it
(
select_lex
->
item_list
);
...
@@ -731,10 +748,13 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -731,10 +748,13 @@ Item_in_subselect::single_value_transformer(JOIN *join,
}
}
else
else
{
{
Item_maxmin_subselect
*
item
;
// remove LIMIT placed by ALL/ANY subquery
// remove LIMIT placed by ALL/ANY subquery
select_lex
->
master_unit
()
->
global_parameters
->
select_limit
=
select_lex
->
master_unit
()
->
global_parameters
->
select_limit
=
HA_POS_ERROR
;
HA_POS_ERROR
;
subs
=
new
Item_maxmin_subselect
(
this
,
select_lex
,
func
->
l_op
());
subs
=
item
=
new
Item_maxmin_subselect
(
this
,
select_lex
,
func
->
l_op
());
if
(
upper_item
)
upper_item
->
set_sub_test
(
item
);
}
}
// left expression belong to outer select
// left expression belong to outer select
SELECT_LEX
*
current
=
thd
->
lex
->
current_select
,
*
up
;
SELECT_LEX
*
current
=
thd
->
lex
->
current_select
,
*
up
;
...
@@ -1041,8 +1061,8 @@ Item_subselect::trans_res
...
@@ -1041,8 +1061,8 @@ Item_subselect::trans_res
Item_allany_subselect
::
select_transformer
(
JOIN
*
join
)
Item_allany_subselect
::
select_transformer
(
JOIN
*
join
)
{
{
transformed
=
1
;
transformed
=
1
;
if
(
upper_
not
)
if
(
upper_
item
)
upper_
not
->
show
=
1
;
upper_
item
->
show
=
1
;
return
single_value_transformer
(
join
,
func
);
return
single_value_transformer
(
join
,
func
);
}
}
...
@@ -1247,6 +1267,7 @@ int subselect_single_select_engine::exec()
...
@@ -1247,6 +1267,7 @@ int subselect_single_select_engine::exec()
}
}
if
(
!
executed
)
if
(
!
executed
)
{
{
item
->
reset_value_registration
();
join
->
exec
();
join
->
exec
();
executed
=
1
;
executed
=
1
;
join
->
thd
->
where
=
save_where
;
join
->
thd
->
where
=
save_where
;
...
...
sql/item_subselect.h
View file @
b2185606
...
@@ -93,7 +93,7 @@ class Item_subselect :public Item_result_field
...
@@ -93,7 +93,7 @@ class Item_subselect :public Item_result_field
return
null_value
;
return
null_value
;
}
}
bool
fix_fields
(
THD
*
thd
,
TABLE_LIST
*
tables
,
Item
**
ref
);
bool
fix_fields
(
THD
*
thd
,
TABLE_LIST
*
tables
,
Item
**
ref
);
bool
exec
();
virtual
bool
exec
();
virtual
void
fix_length_and_dec
();
virtual
void
fix_length_and_dec
();
table_map
used_tables
()
const
;
table_map
used_tables
()
const
;
bool
const_item
()
const
;
bool
const_item
()
const
;
...
@@ -109,6 +109,11 @@ class Item_subselect :public Item_result_field
...
@@ -109,6 +109,11 @@ class Item_subselect :public Item_result_field
engine_changed
=
1
;
engine_changed
=
1
;
return
eng
==
0
;
return
eng
==
0
;
}
}
/*
Used by max/min subquery to initialize value presence registration
mechanism. Engine call this method before rexecution query.
*/
virtual
void
reset_value_registration
()
{}
friend
class
select_subselect
;
friend
class
select_subselect
;
friend
class
Item_in_optimizer
;
friend
class
Item_in_optimizer
;
...
@@ -150,13 +155,20 @@ class Item_singlerow_subselect :public Item_subselect
...
@@ -150,13 +155,20 @@ class Item_singlerow_subselect :public Item_subselect
};
};
/* used in static ALL/ANY optimisation */
/* used in static ALL/ANY optimisation */
class
select_max_min_finder_subselect
;
class
Item_maxmin_subselect
:
public
Item_singlerow_subselect
class
Item_maxmin_subselect
:
public
Item_singlerow_subselect
{
{
protected:
bool
max
;
bool
max
;
bool
was_values
;
// was checked at least some values
public:
public:
Item_maxmin_subselect
(
Item_subselect
*
parent
,
Item_maxmin_subselect
(
Item_subselect
*
parent
,
st_select_lex
*
select_lex
,
bool
max
);
st_select_lex
*
select_lex
,
bool
max
);
void
print
(
String
*
str
);
void
print
(
String
*
str
);
void
cleanup
();
bool
any_value
()
{
return
was_values
;
}
void
register_value
()
{
was_values
=
TRUE
;
}
void
reset_value_registration
()
{
was_values
=
FALSE
;
}
};
};
/* exists subselect */
/* exists subselect */
...
@@ -204,11 +216,11 @@ class Item_in_subselect :public Item_exists_subselect
...
@@ -204,11 +216,11 @@ class Item_in_subselect :public Item_exists_subselect
bool
abort_on_null
;
bool
abort_on_null
;
bool
transformed
;
bool
transformed
;
public:
public:
Item_func_not_all
*
upper_
not
;
// point on NOT before ALL
subquery
Item_func_not_all
*
upper_
item
;
// point on NOT/NOP before ALL/SOME
subquery
Item_in_subselect
(
Item
*
left_expr
,
st_select_lex
*
select_lex
);
Item_in_subselect
(
Item
*
left_expr
,
st_select_lex
*
select_lex
);
Item_in_subselect
()
Item_in_subselect
()
:
Item_exists_subselect
(),
abort_on_null
(
0
),
transformed
(
0
),
upper_
not
(
0
)
:
Item_exists_subselect
(),
abort_on_null
(
0
),
transformed
(
0
),
upper_
item
(
0
)
{}
{}
...
@@ -249,7 +261,7 @@ class Item_allany_subselect :public Item_in_subselect
...
@@ -249,7 +261,7 @@ class Item_allany_subselect :public Item_in_subselect
st_select_lex
*
select_lex
,
bool
all
);
st_select_lex
*
select_lex
,
bool
all
);
// only ALL subquery has upper not
// only ALL subquery has upper not
subs_type
substype
()
{
return
upper_not
?
ALL_SUBS
:
ANY_SUBS
;
}
subs_type
substype
()
{
return
all
?
ALL_SUBS
:
ANY_SUBS
;
}
trans_res
select_transformer
(
JOIN
*
join
);
trans_res
select_transformer
(
JOIN
*
join
);
void
print
(
String
*
str
);
void
print
(
String
*
str
);
};
};
...
...
sql/item_sum.cc
View file @
b2185606
...
@@ -537,9 +537,22 @@ void Item_sum_hybrid::cleanup()
...
@@ -537,9 +537,22 @@ void Item_sum_hybrid::cleanup()
DBUG_ENTER
(
"Item_sum_hybrid::cleanup"
);
DBUG_ENTER
(
"Item_sum_hybrid::cleanup"
);
Item_sum
::
cleanup
();
Item_sum
::
cleanup
();
used_table_cache
=
~
(
table_map
)
0
;
used_table_cache
=
~
(
table_map
)
0
;
/*
by default is is TRUE to avoid TRUE reporting by
Item_func_not_all/Item_func_nop_all if this item was never called.
no_rows_in_result() set it to FALSE if was not results found.
*/
was_values
=
TRUE
;
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_sum_hybrid
::
no_rows_in_result
()
{
Item_sum
::
no_rows_in_result
();
was_values
=
FALSE
;
}
Item
*
Item_sum_min
::
copy_or_same
(
THD
*
thd
)
Item
*
Item_sum_min
::
copy_or_same
(
THD
*
thd
)
{
{
...
...
sql/item_sum.h
View file @
b2185606
...
@@ -402,18 +402,20 @@ class Item_sum_hybrid :public Item_sum
...
@@ -402,18 +402,20 @@ class Item_sum_hybrid :public Item_sum
enum_field_types
hybrid_field_type
;
enum_field_types
hybrid_field_type
;
int
cmp_sign
;
int
cmp_sign
;
table_map
used_table_cache
;
table_map
used_table_cache
;
bool
was_values
;
// was checked at least some values (for max/min only)
public:
public:
Item_sum_hybrid
(
Item
*
item_par
,
int
sign
)
Item_sum_hybrid
(
Item
*
item_par
,
int
sign
)
:
Item_sum
(
item_par
),
sum
(
0.0
),
sum_int
(
0
),
:
Item_sum
(
item_par
),
sum
(
0.0
),
sum_int
(
0
),
hybrid_type
(
INT_RESULT
),
hybrid_field_type
(
FIELD_TYPE_LONGLONG
),
hybrid_type
(
INT_RESULT
),
hybrid_field_type
(
FIELD_TYPE_LONGLONG
),
cmp_sign
(
sign
),
used_table_cache
(
~
(
table_map
)
0
)
cmp_sign
(
sign
),
used_table_cache
(
~
(
table_map
)
0
)
,
was_values
(
TRUE
)
{
collation
.
set
(
&
my_charset_bin
);
}
{
collation
.
set
(
&
my_charset_bin
);
}
Item_sum_hybrid
(
THD
*
thd
,
Item_sum_hybrid
*
item
)
:
Item_sum_hybrid
(
THD
*
thd
,
Item_sum_hybrid
*
item
)
:
Item_sum
(
thd
,
item
),
value
(
item
->
value
),
Item_sum
(
thd
,
item
),
value
(
item
->
value
),
sum
(
item
->
sum
),
sum_int
(
item
->
sum_int
),
hybrid_type
(
item
->
hybrid_type
),
sum
(
item
->
sum
),
sum_int
(
item
->
sum_int
),
hybrid_type
(
item
->
hybrid_type
),
hybrid_field_type
(
item
->
hybrid_field_type
),
cmp_sign
(
item
->
cmp_sign
),
hybrid_field_type
(
item
->
hybrid_field_type
),
cmp_sign
(
item
->
cmp_sign
),
used_table_cache
(
item
->
used_table_cache
)
used_table_cache
(
item
->
used_table_cache
),
was_values
(
TRUE
)
{
collation
.
set
(
item
->
collation
);
}
{
collation
.
set
(
item
->
collation
);
}
bool
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
bool
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
table_map
used_tables
()
const
{
return
used_table_cache
;
}
table_map
used_tables
()
const
{
return
used_table_cache
;
}
...
@@ -433,6 +435,8 @@ class Item_sum_hybrid :public Item_sum
...
@@ -433,6 +435,8 @@ class Item_sum_hybrid :public Item_sum
void
min_max_update_real_field
();
void
min_max_update_real_field
();
void
min_max_update_int_field
();
void
min_max_update_int_field
();
void
cleanup
();
void
cleanup
();
bool
any_value
()
{
return
was_values
;
}
void
no_rows_in_result
();
};
};
...
...
sql/sql_class.cc
View file @
b2185606
...
@@ -1244,9 +1244,10 @@ bool select_singlerow_subselect::send_data(List<Item> &items)
...
@@ -1244,9 +1244,10 @@ bool select_singlerow_subselect::send_data(List<Item> &items)
bool
select_max_min_finder_subselect
::
send_data
(
List
<
Item
>
&
items
)
bool
select_max_min_finder_subselect
::
send_data
(
List
<
Item
>
&
items
)
{
{
DBUG_ENTER
(
"select_max_min_finder_subselect::send_data"
);
DBUG_ENTER
(
"select_max_min_finder_subselect::send_data"
);
Item_
singlerow_subselect
*
it
=
(
Item_singlerow
_subselect
*
)
item
;
Item_
maxmin_subselect
*
it
=
(
Item_maxmin
_subselect
*
)
item
;
List_iterator_fast
<
Item
>
li
(
items
);
List_iterator_fast
<
Item
>
li
(
items
);
Item
*
val_item
=
li
++
;
Item
*
val_item
=
li
++
;
it
->
register_value
();
if
(
it
->
assigned
())
if
(
it
->
assigned
())
{
{
cache
->
store
(
val_item
);
cache
->
store
(
val_item
);
...
...
sql/sql_parse.cc
View file @
b2185606
...
@@ -5085,9 +5085,9 @@ Item * all_any_subquery_creator(Item *left_expr,
...
@@ -5085,9 +5085,9 @@ Item * all_any_subquery_creator(Item *left_expr,
Item_allany_subselect
*
it
=
Item_allany_subselect
*
it
=
new
Item_allany_subselect
(
left_expr
,
(
*
cmp
)(
all
),
select_lex
,
all
);
new
Item_allany_subselect
(
left_expr
,
(
*
cmp
)(
all
),
select_lex
,
all
);
if
(
all
)
if
(
all
)
return
it
->
upper_
not
=
new
Item_func_not_all
(
it
);
/* ALL */
return
it
->
upper_
item
=
new
Item_func_not_all
(
it
);
/* ALL */
return
it
;
/* ANY/SOME */
return
it
->
upper_item
=
new
Item_func_nop_all
(
it
);
/* ANY/SOME */
}
}
...
...
sql/sql_union.cc
View file @
b2185606
...
@@ -394,6 +394,8 @@ int st_select_lex_unit::exec()
...
@@ -394,6 +394,8 @@ int st_select_lex_unit::exec()
if
(
uncacheable
||
!
item
||
!
item
->
assigned
()
||
describe
)
if
(
uncacheable
||
!
item
||
!
item
->
assigned
()
||
describe
)
{
{
if
(
item
)
item
->
reset_value_registration
();
if
(
optimized
&&
item
)
if
(
optimized
&&
item
)
{
{
if
(
item
->
assigned
())
if
(
item
->
assigned
())
...
...
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