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
d2fa79b2
Commit
d2fa79b2
authored
May 07, 2004
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
keep old engine & JOIN if we changed subquery Item (Bug #3646)
parent
5c4f83bb
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
291 additions
and
20 deletions
+291
-20
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+89
-0
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+33
-1
sql/item_subselect.cc
sql/item_subselect.cc
+98
-9
sql/item_subselect.h
sql/item_subselect.h
+4
-0
sql/item_sum.cc
sql/item_sum.cc
+8
-0
sql/item_sum.h
sql/item_sum.h
+1
-7
sql/sql_lex.cc
sql/sql_lex.cc
+2
-1
sql/sql_lex.h
sql/sql_lex.h
+1
-0
sql/sql_select.cc
sql/sql_select.cc
+25
-2
sql/sql_select.h
sql/sql_select.h
+1
-0
sql/sql_union.cc
sql/sql_union.cc
+29
-0
No files found.
mysql-test/r/subselect.result
View file @
d2fa79b2
...
@@ -1719,3 +1719,92 @@ SELECT t1.id, ( SELECT COUNT(t.id) FROM t2 AS t WHERE t.id = t1.id ) AS c FROM t
...
@@ -1719,3 +1719,92 @@ SELECT t1.id, ( SELECT COUNT(t.id) FROM t2 AS t WHERE t.id = t1.id ) AS c FROM t
id c
id c
1 1
1 1
2 0
2 0
DROP TABLE t1,t2;
CREATE TABLE t1 ( a int, b int );
INSERT INTO t1 VALUES (1,1),(2,2),(3,3);
SELECT a FROM t1 WHERE a > ANY ( SELECT a FROM t1 WHERE b = 2 );
a
3
SELECT a FROM t1 WHERE a < ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
SELECT a FROM t1 WHERE a = ANY ( SELECT a FROM t1 WHERE b = 2 );
a
2
SELECT a FROM t1 WHERE a >= ANY ( SELECT a FROM t1 WHERE b = 2 );
a
2
3
SELECT a FROM t1 WHERE a <= ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
2
SELECT a FROM t1 WHERE a <> ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
3
SELECT a FROM t1 WHERE a > ALL ( SELECT a FROM t1 WHERE b = 2 );
a
3
SELECT a FROM t1 WHERE a < ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
SELECT a FROM t1 WHERE a = ALL ( SELECT a FROM t1 WHERE b = 2 );
a
2
SELECT a FROM t1 WHERE a >= ALL ( SELECT a FROM t1 WHERE b = 2 );
a
2
3
SELECT a FROM t1 WHERE a <= ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
2
SELECT a FROM t1 WHERE a <> ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
3
ALTER TABLE t1 ADD INDEX (a);
SELECT a FROM t1 WHERE a > ANY ( SELECT a FROM t1 WHERE b = 2 );
a
3
SELECT a FROM t1 WHERE a < ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
SELECT a FROM t1 WHERE a = ANY ( SELECT a FROM t1 WHERE b = 2 );
a
2
SELECT a FROM t1 WHERE a >= ANY ( SELECT a FROM t1 WHERE b = 2 );
a
2
3
SELECT a FROM t1 WHERE a <= ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
2
SELECT a FROM t1 WHERE a <> ANY ( SELECT a FROM t1 WHERE b = 2 );
a
1
3
SELECT a FROM t1 WHERE a > ALL ( SELECT a FROM t1 WHERE b = 2 );
a
3
SELECT a FROM t1 WHERE a < ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
SELECT a FROM t1 WHERE a = ALL ( SELECT a FROM t1 WHERE b = 2 );
a
2
SELECT a FROM t1 WHERE a >= ALL ( SELECT a FROM t1 WHERE b = 2 );
a
2
3
SELECT a FROM t1 WHERE a <= ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
2
SELECT a FROM t1 WHERE a <> ALL ( SELECT a FROM t1 WHERE b = 2 );
a
1
3
DROP TABLE t1;
mysql-test/t/subselect.test
View file @
d2fa79b2
...
@@ -1125,4 +1125,36 @@ INSERT INTO t1 VALUES (1), (2);
...
@@ -1125,4 +1125,36 @@ INSERT INTO t1 VALUES (1), (2);
INSERT
INTO
t2
VALUES
(
1
);
INSERT
INTO
t2
VALUES
(
1
);
SELECT
t1
.
id
,
(
SELECT
COUNT
(
t
.
id
)
FROM
t2
AS
t
WHERE
t
.
id
=
t1
.
id
)
AS
c
FROM
t1
LEFT
JOIN
t2
USING
(
id
);
SELECT
t1
.
id
,
(
SELECT
COUNT
(
t
.
id
)
FROM
t2
AS
t
WHERE
t
.
id
=
t1
.
id
)
AS
c
FROM
t1
LEFT
JOIN
t2
USING
(
id
);
SELECT
t1
.
id
,
(
SELECT
COUNT
(
t
.
id
)
FROM
t2
AS
t
WHERE
t
.
id
=
t1
.
id
)
AS
c
FROM
t1
LEFT
JOIN
t2
USING
(
id
)
ORDER
BY
t1
.
id
;
SELECT
t1
.
id
,
(
SELECT
COUNT
(
t
.
id
)
FROM
t2
AS
t
WHERE
t
.
id
=
t1
.
id
)
AS
c
FROM
t1
LEFT
JOIN
t2
USING
(
id
)
ORDER
BY
t1
.
id
;
DROP
TABLE
t1
,
t2
DROP
TABLE
t1
,
t2
;
#
# ALL/ANY test
#
CREATE
TABLE
t1
(
a
int
,
b
int
);
INSERT
INTO
t1
VALUES
(
1
,
1
),(
2
,
2
),(
3
,
3
);
SELECT
a
FROM
t1
WHERE
a
>
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<>
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<>
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
ALTER
TABLE
t1
ADD
INDEX
(
a
);
SELECT
a
FROM
t1
WHERE
a
>
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<=
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<>
ANY
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
>=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<=
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
SELECT
a
FROM
t1
WHERE
a
<>
ALL
(
SELECT
a
FROM
t1
WHERE
b
=
2
);
DROP
TABLE
t1
;
sql/item_subselect.cc
View file @
d2fa79b2
...
@@ -56,10 +56,24 @@ void Item_subselect::init(st_select_lex *select_lex,
...
@@ -56,10 +56,24 @@ void Item_subselect::init(st_select_lex *select_lex,
DBUG_PRINT
(
"subs"
,
(
"select_lex 0x%xl"
,
(
ulong
)
select_lex
));
DBUG_PRINT
(
"subs"
,
(
"select_lex 0x%xl"
,
(
ulong
)
select_lex
));
unit
=
select_lex
->
master_unit
();
unit
=
select_lex
->
master_unit
();
if
(
unit
->
item
)
{
/*
Item can be changed in JOIN::prepare while engine in JOIN::optimize
=> we do not copy old_engine here
*/
engine
=
unit
->
item
->
engine
;
unit
->
item
->
engine
=
0
;
unit
->
item
=
this
;
engine
->
change_item
(
this
,
result
);
}
else
{
if
(
select_lex
->
next_select
())
if
(
select_lex
->
next_select
())
engine
=
new
subselect_union_engine
(
unit
,
result
,
this
);
engine
=
new
subselect_union_engine
(
unit
,
result
,
this
);
else
else
engine
=
new
subselect_single_select_engine
(
select_lex
,
result
,
this
);
engine
=
new
subselect_single_select_engine
(
select_lex
,
result
,
this
);
}
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
...
@@ -69,10 +83,12 @@ void Item_subselect::cleanup()
...
@@ -69,10 +83,12 @@ void Item_subselect::cleanup()
Item_result_field
::
cleanup
();
Item_result_field
::
cleanup
();
if
(
old_engine
)
if
(
old_engine
)
{
{
if
(
engine
)
engine
->
cleanup
();
engine
->
cleanup
();
engine
=
old_engine
;
engine
=
old_engine
;
old_engine
=
0
;
old_engine
=
0
;
}
}
if
(
engine
)
engine
->
cleanup
();
engine
->
cleanup
();
reset
();
reset
();
value_assigned
=
0
;
value_assigned
=
0
;
...
@@ -127,7 +143,6 @@ bool Item_subselect::fix_fields(THD *thd_param, TABLE_LIST *tables, Item **ref)
...
@@ -127,7 +143,6 @@ bool Item_subselect::fix_fields(THD *thd_param, TABLE_LIST *tables, Item **ref)
if
(
have_to_be_excluded
)
if
(
have_to_be_excluded
)
engine
->
exclude
();
engine
->
exclude
();
substitution
=
0
;
substitution
=
0
;
fixed
=
1
;
thd
->
where
=
"checking transformed subquery"
;
thd
->
where
=
"checking transformed subquery"
;
if
(
!
(
*
ref
)
->
fixed
)
if
(
!
(
*
ref
)
->
fixed
)
ret
=
(
*
ref
)
->
fix_fields
(
thd
,
tables
,
ref
);
ret
=
(
*
ref
)
->
fix_fields
(
thd
,
tables
,
ref
);
...
@@ -660,10 +675,20 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -660,10 +675,20 @@ 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
);
}
}
*
select_lex
->
ref_pointer_array
=
item
;
*
select_lex
->
ref_pointer_array
=
item
;
select_lex
->
item_list
.
empty
();
{
select_lex
->
item_list
.
push_back
(
item
);
List_iterator
<
Item
>
it
(
select_lex
->
item_list
);
it
++
;
it
.
replace
(
item
);
}
// fix_fields call for 'item' will be made during new subquery fix_fields
/*
Item_sum_(max|min) can't substitute other item => we can use 0 as
reference
*/
if
(
item
->
fix_fields
(
thd
,
join
->
tables_list
,
0
))
goto
err
;
/* we added aggregate function => we have to change statistic */
count_field_types
(
&
join
->
tmp_table_param
,
join
->
all_fields
,
0
);
subs
=
new
Item_singlerow_subselect
(
select_lex
);
subs
=
new
Item_singlerow_subselect
(
select_lex
);
}
}
...
@@ -1428,3 +1453,67 @@ void subselect_indexsubquery_engine::print(String *str)
...
@@ -1428,3 +1453,67 @@ void subselect_indexsubquery_engine::print(String *str)
}
}
str
->
append
(
')'
);
str
->
append
(
')'
);
}
}
/*
change select_result object of engine
SINOPSYS
subselect_single_select_engine::change_result()
si new subselect Item
res new select_result object
RETURN
0 OK
-1 error
*/
int
subselect_single_select_engine
::
change_item
(
Item_subselect
*
si
,
select_subselect
*
res
)
{
item
=
si
;
result
=
res
;
return
select_lex
->
join
->
change_result
(
result
);
}
/*
change select_result object of engine
SINOPSYS
subselect_single_select_engine::change_result()
si new subselect Item
res new select_result object
RETURN
0 OK
-1 error
*/
int
subselect_union_engine
::
change_item
(
Item_subselect
*
si
,
select_subselect
*
res
)
{
item
=
si
;
int
rc
=
unit
->
change_result
(
res
,
result
);
result
=
res
;
return
rc
;
}
/*
change select_result emulation, never should be called
SINOPSYS
subselect_single_select_engine::change_result()
si new subselect Item
res new select_result object
RETURN
-1 error
*/
int
subselect_uniquesubquery_engine
::
change_item
(
Item_subselect
*
si
,
select_subselect
*
res
)
{
DBUG_ASSERT
(
0
);
return
-
1
;
}
sql/item_subselect.h
View file @
d2fa79b2
...
@@ -290,6 +290,7 @@ public:
...
@@ -290,6 +290,7 @@ public:
virtual
table_map
upper_select_const_tables
()
=
0
;
virtual
table_map
upper_select_const_tables
()
=
0
;
static
table_map
calc_const_tables
(
TABLE_LIST
*
);
static
table_map
calc_const_tables
(
TABLE_LIST
*
);
virtual
void
print
(
String
*
str
)
=
0
;
virtual
void
print
(
String
*
str
)
=
0
;
virtual
int
change_item
(
Item_subselect
*
si
,
select_subselect
*
result
)
=
0
;
};
};
...
@@ -313,6 +314,7 @@ public:
...
@@ -313,6 +314,7 @@ public:
void
exclude
();
void
exclude
();
table_map
upper_select_const_tables
();
table_map
upper_select_const_tables
();
void
print
(
String
*
str
);
void
print
(
String
*
str
);
int
change_item
(
Item_subselect
*
si
,
select_subselect
*
result
);
};
};
...
@@ -332,6 +334,7 @@ public:
...
@@ -332,6 +334,7 @@ public:
void
exclude
();
void
exclude
();
table_map
upper_select_const_tables
();
table_map
upper_select_const_tables
();
void
print
(
String
*
str
);
void
print
(
String
*
str
);
int
change_item
(
Item_subselect
*
si
,
select_subselect
*
result
);
};
};
...
@@ -360,6 +363,7 @@ public:
...
@@ -360,6 +363,7 @@ public:
void
exclude
();
void
exclude
();
table_map
upper_select_const_tables
()
{
return
0
;
}
table_map
upper_select_const_tables
()
{
return
0
;
}
void
print
(
String
*
str
);
void
print
(
String
*
str
);
int
change_item
(
Item_subselect
*
si
,
select_subselect
*
result
);
};
};
...
...
sql/item_sum.cc
View file @
d2fa79b2
...
@@ -502,6 +502,14 @@ void Item_sum_variance::update_field()
...
@@ -502,6 +502,14 @@ void Item_sum_variance::update_field()
/* min & max */
/* min & max */
void
Item_sum_hybrid
::
clear
()
{
sum
=
0.0
;
sum_int
=
0
;
value
.
length
(
0
);
null_value
=
1
;
}
double
Item_sum_hybrid
::
val
()
double
Item_sum_hybrid
::
val
()
{
{
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
...
...
sql/item_sum.h
View file @
d2fa79b2
...
@@ -415,13 +415,7 @@ class Item_sum_hybrid :public Item_sum
...
@@ -415,13 +415,7 @@ class Item_sum_hybrid :public Item_sum
table_map
used_tables
()
const
{
return
used_table_cache
;
}
table_map
used_tables
()
const
{
return
used_table_cache
;
}
bool
const_item
()
const
{
return
!
used_table_cache
;
}
bool
const_item
()
const
{
return
!
used_table_cache
;
}
void
clear
()
void
clear
();
{
sum
=
0.0
;
sum_int
=
0
;
value
.
length
(
0
);
null_value
=
1
;
}
double
val
();
double
val
();
longlong
val_int
();
longlong
val_int
();
void
reset_field
();
void
reset_field
();
...
...
sql/sql_lex.cc
View file @
d2fa79b2
...
@@ -1710,6 +1710,7 @@ TABLE_LIST *st_lex::link_first_table_back(TABLE_LIST *tables,
...
@@ -1710,6 +1710,7 @@ TABLE_LIST *st_lex::link_first_table_back(TABLE_LIST *tables,
st_select_lex::print is in sql_select.h
st_select_lex::print is in sql_select.h
st_select_lex_unit::prepare, st_select_lex_unit::exec,
st_select_lex_unit::prepare, st_select_lex_unit::exec,
st_select_lex_unit::cleanup, st_select_lex_unit::reinit_exec_mechanism
st_select_lex_unit::cleanup, st_select_lex_unit::reinit_exec_mechanism,
st_select_lex_unit::change_result
are in sql_union.cc
are in sql_union.cc
*/
*/
sql/sql_lex.h
View file @
d2fa79b2
...
@@ -371,6 +371,7 @@ public:
...
@@ -371,6 +371,7 @@ public:
void
print
(
String
*
str
);
void
print
(
String
*
str
);
ulong
init_prepare_fake_select_lex
(
THD
*
thd
);
ulong
init_prepare_fake_select_lex
(
THD
*
thd
);
int
change_result
(
select_subselect
*
result
,
select_subselect
*
old_result
);
friend
void
mysql_init_query
(
THD
*
thd
);
friend
void
mysql_init_query
(
THD
*
thd
);
friend
int
subselect_union_engine
::
exec
();
friend
int
subselect_union_engine
::
exec
();
...
...
sql/sql_select.cc
View file @
d2fa79b2
...
@@ -1585,8 +1585,7 @@ mysql_select(THD *thd, Item ***rref_pointer_array,
...
@@ -1585,8 +1585,7 @@ mysql_select(THD *thd, Item ***rref_pointer_array,
if
(
select_lex
->
linkage
!=
GLOBAL_OPTIONS_TYPE
)
if
(
select_lex
->
linkage
!=
GLOBAL_OPTIONS_TYPE
)
{
{
//here is EXPLAIN of subselect or derived table
//here is EXPLAIN of subselect or derived table
join
->
result
=
result
;
if
(
join
->
change_result
(
result
))
if
(
!
join
->
procedure
&&
result
->
prepare
(
join
->
fields_list
,
unit
))
{
{
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
}
}
...
@@ -9514,3 +9513,27 @@ void st_select_lex::print(THD *thd, String *str)
...
@@ -9514,3 +9513,27 @@ void st_select_lex::print(THD *thd, String *str)
// PROCEDURE unsupported here
// PROCEDURE unsupported here
}
}
/*
change select_result object of JOIN
SYNOPSIS
JOIN::change_result()
res new select_result object
RETURN
0 - OK
-1 - error
*/
int
JOIN
::
change_result
(
select_result
*
res
)
{
DBUG_ENTER
(
"JOIN::change_result"
);
result
=
res
;
if
(
!
procedure
&&
result
->
prepare
(
fields_list
,
select_lex
->
master_unit
()))
{
DBUG_RETURN
(
-
1
);
}
DBUG_RETURN
(
0
);
}
sql/sql_select.h
View file @
d2fa79b2
...
@@ -304,6 +304,7 @@ class JOIN :public Sql_alloc
...
@@ -304,6 +304,7 @@ class JOIN :public Sql_alloc
return
(
do_send_rows
&&
tmp_table_param
.
sum_func_count
!=
0
&&
return
(
do_send_rows
&&
tmp_table_param
.
sum_func_count
!=
0
&&
!
group_list
);
!
group_list
);
}
}
int
change_result
(
select_result
*
result
);
};
};
...
...
sql/sql_union.cc
View file @
d2fa79b2
...
@@ -555,3 +555,32 @@ void st_select_lex_unit::reinit_exec_mechanism()
...
@@ -555,3 +555,32 @@ void st_select_lex_unit::reinit_exec_mechanism()
}
}
#endif
#endif
}
}
/*
change select_result object of unit
SYNOPSIS
st_select_lex_unit::change_result()
result new select_result object
old_result old select_result object
RETURN
0 - OK
-1 - error
*/
int
st_select_lex_unit
::
change_result
(
select_subselect
*
result
,
select_subselect
*
old_result
)
{
int
res
=
0
;
for
(
SELECT_LEX
*
sl
=
first_select_in_union
();
sl
;
sl
=
sl
->
next_select
())
{
if
(
sl
->
join
&&
sl
->
join
->
result
==
old_result
)
if
((
res
=
sl
->
join
->
change_result
(
result
)))
return
(
res
);
}
if
(
fake_select_lex
&&
fake_select_lex
->
join
)
res
=
fake_select_lex
->
join
->
change_result
(
result
);
return
(
res
);
}
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