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
e59f1917
Commit
e59f1917
authored
Nov 01, 2006
by
sergefp@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
BUG#8804: Incorrect results for NULL IN (SELECT ...): review fixes:
- Better comments - Remove redundant and dead code.
parent
cc05fbd7
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
20 deletions
+18
-20
sql/item_subselect.cc
sql/item_subselect.cc
+18
-20
No files found.
sql/item_subselect.cc
View file @
e59f1917
...
@@ -769,43 +769,47 @@ my_decimal *Item_in_subselect::val_decimal(my_decimal *decimal_value)
...
@@ -769,43 +769,47 @@ my_decimal *Item_in_subselect::val_decimal(my_decimal *decimal_value)
SYNOPSIS
SYNOPSIS
Item_in_subselect::single_value_transformer()
Item_in_subselect::single_value_transformer()
join
join
Join object of the subquery (i.e. 'child' join).
func
func
Subquery comparison creator
DESCRIPTION
DESCRIPTION
Rewrite a single-column subquery using rule-based approach. The subquery
Rewrite a single-column subquery using rule-based approach. The subquery
oe $cmp$ (SELECT
sel FROM ... WHERE subq_where
HAVING subq_having)
oe $cmp$ (SELECT
ie FROM ... WHERE subq_where ...
HAVING subq_having)
First, try to convert the subquery to scalar-result subquery in one of
First, try to convert the subquery to scalar-result subquery in one of
the forms:
the forms:
- oe $cmp$ (SELECT MAX(...) ) // handled by Item_singlerow_subselect
- oe $cmp$ (SELECT MAX(...) ) // handled by Item_singlerow_subselect
- oe $cmp$ <max>(SELECT ...) // handled by Item_maxminsubselect
- oe $cmp$ <max>(SELECT ...) // handled by Item_maxmin
_
subselect
If that fails, the subquery will be handled with class Item_in_optimizer,
If that fails, the subquery will be handled with class Item_in_optimizer,
Inject the predicates into subquery, i.e. convert it to:
Inject the predicates into subquery, i.e. convert it to:
- If the subquery has aggregates, GROUP BY, or HAVING, convert to
- If the subquery has aggregates, GROUP BY, or HAVING, convert to
SELECT
sel
FROM ... HAVING subq_having AND
SELECT
ie
FROM ... HAVING subq_having AND
trigcond(oe $cmp$ ref_or_null_helper<ie>)
trigcond(oe $cmp$ ref_or_null_helper<ie>)
the addition is wrapped into trigger only when we want to distinguish
the addition is wrapped into trigger only when we want to distinguish
between NULL and FALSE results.
between NULL and FALSE results.
- Else, if we don't care if subquery result is NULL or FALSE, convert to
- Otherwise (no aggregates/GROUP BY/HAVING) convert it to one of the
following:
SELECT 1 ... WHERE (oe $CMP$ ie) AND subq_where
- Else convert to:
= If we don't need to distinguish between NULL and FALSE subquery:
SELECT 1 FROM ... WHERE (oe $cmp$ ie) AND subq_where
SELECT 1 WHERE ...
= If we need to distinguish between those:
WHERE subq_where AND trigcond((oe $CMP$ ie) OR ie IS NULL)
HAVING subq_having AND trigcond(<is_not_null_test>(ie))
SELECT 1 FROM ...
WHERE subq_where AND trigcond((oe $cmp$ ie) OR (ie IS NULL))
HAVING trigcond(<is_not_null_test>(ie))
RETURN
RETURN
RES_OK - Transformed successfully (or done nothing?)
RES_OK - OK, either subquery was transformed, or appopriate
predicates where injected into it.
RES_REDUCE - The subquery was reduced to non-subquery
RES_REDUCE - The subquery was reduced to non-subquery
RES_ERROR - Error
RES_ERROR - Error
*/
*/
...
@@ -1010,10 +1014,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -1010,10 +1014,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
we can assign select_lex->having here, and pass 0 as last
we can assign select_lex->having here, and pass 0 as last
argument (reference) to fix_fields()
argument (reference) to fix_fields()
*/
*/
select_lex
->
having
=
select_lex
->
having
=
join
->
having
=
having
;
join
->
having
=
(
join
->
having
?
new
Item_cond_and
(
having
,
join
->
having
)
:
having
);
select_lex
->
having_fix_field
=
1
;
select_lex
->
having_fix_field
=
1
;
/*
/*
we do not check join->having->fixed, because Item_and (from
we do not check join->having->fixed, because Item_and (from
...
@@ -1608,7 +1609,6 @@ int subselect_uniquesubquery_engine::prepare()
...
@@ -1608,7 +1609,6 @@ int subselect_uniquesubquery_engine::prepare()
bool
subselect_single_select_engine
::
no_rows
()
bool
subselect_single_select_engine
::
no_rows
()
{
{
// return test(!join->send_records);
return
!
item
->
assigned
();
return
!
item
->
assigned
();
}
}
...
@@ -1791,9 +1791,7 @@ int subselect_uniquesubquery_engine::scan_table()
...
@@ -1791,9 +1791,7 @@ int subselect_uniquesubquery_engine::scan_table()
int
error
;
int
error
;
TABLE
*
table
=
tab
->
table
;
TABLE
*
table
=
tab
->
table
;
DBUG_ENTER
(
"subselect_uniquesubquery_engine::scan_table"
);
DBUG_ENTER
(
"subselect_uniquesubquery_engine::scan_table"
);
empty_result_set
=
TRUE
;
empty_result_set
=
TRUE
;
bool
is_uncorrelated
=
!
cond
||
!
(
cond
->
used_tables
()
&
OUTER_REF_TABLE_BIT
);
if
(
table
->
file
->
inited
)
if
(
table
->
file
->
inited
)
table
->
file
->
ha_index_end
();
table
->
file
->
ha_index_end
();
...
...
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