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
abfa5514
Commit
abfa5514
authored
Nov 02, 2003
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
merge
parents
8e80431f
777316c3
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
29 additions
and
16 deletions
+29
-16
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+7
-0
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+10
-0
sql/item_subselect.cc
sql/item_subselect.cc
+5
-7
sql/item_subselect.h
sql/item_subselect.h
+1
-3
sql/set_var.cc
sql/set_var.cc
+5
-1
sql/sql_select.cc
sql/sql_select.cc
+1
-5
No files found.
mysql-test/r/subselect.result
View file @
abfa5514
...
@@ -1486,3 +1486,10 @@ ERROR 42S22: Unknown column 't1.s2' in 'group statement'
...
@@ -1486,3 +1486,10 @@ ERROR 42S22: Unknown column 't1.s2' in 'group statement'
select count(*) from t2 group by t1.s2;
select count(*) from t2 group by t1.s2;
ERROR 42S02: Unknown table 't1' in group statement
ERROR 42S02: Unknown table 't1' in group statement
drop table t1, t2;
drop table t1, t2;
CREATE TABLE t1(COLA FLOAT NOT NULL,COLB FLOAT NOT NULL,COLC VARCHAR(20) DEFAULT NULL,PRIMARY KEY (COLA, COLB));
CREATE TABLE t2(COLA FLOAT NOT NULL,COLB FLOAT NOT NULL,COLC CHAR(1) NOT NULL,PRIMARY KEY (COLA));
INSERT INTO t1 VALUES (1,1,'1A3240'), (1,2,'4W2365');
INSERT INTO t2 VALUES (100, 200, 'C');
SELECT DISTINCT COLC FROM t1 WHERE COLA = (SELECT COLA FROM t2 WHERE COLB = 200 AND COLC ='C' LIMIT 1);
COLC
DROP TABLE t1, t2;
mysql-test/t/subselect.test
View file @
abfa5514
...
@@ -999,3 +999,13 @@ select * from t1 where (select count(*) from t2 group by t1.s2) = 1;
...
@@ -999,3 +999,13 @@ select * from t1 where (select count(*) from t2 group by t1.s2) = 1;
--
error
1109
--
error
1109
select
count
(
*
)
from
t2
group
by
t1
.
s2
;
select
count
(
*
)
from
t2
group
by
t1
.
s2
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
#
# fix_fields() in add_ref_to_table_cond()
#
CREATE
TABLE
t1
(
COLA
FLOAT
NOT
NULL
,
COLB
FLOAT
NOT
NULL
,
COLC
VARCHAR
(
20
)
DEFAULT
NULL
,
PRIMARY
KEY
(
COLA
,
COLB
));
CREATE
TABLE
t2
(
COLA
FLOAT
NOT
NULL
,
COLB
FLOAT
NOT
NULL
,
COLC
CHAR
(
1
)
NOT
NULL
,
PRIMARY
KEY
(
COLA
));
INSERT
INTO
t1
VALUES
(
1
,
1
,
'1A3240'
),
(
1
,
2
,
'4W2365'
);
INSERT
INTO
t2
VALUES
(
100
,
200
,
'C'
);
SELECT
DISTINCT
COLC
FROM
t1
WHERE
COLA
=
(
SELECT
COLA
FROM
t2
WHERE
COLB
=
200
AND
COLC
=
'C'
LIMIT
1
);
DROP
TABLE
t1
,
t2
;
s
sql/item_subselect.cc
View file @
abfa5514
...
@@ -512,7 +512,6 @@ String *Item_in_subselect::val_str(String *str)
...
@@ -512,7 +512,6 @@ String *Item_in_subselect::val_str(String *str)
Item_subselect
::
trans_res
Item_subselect
::
trans_res
Item_in_subselect
::
single_value_transformer
(
JOIN
*
join
,
Item_in_subselect
::
single_value_transformer
(
JOIN
*
join
,
Item
*
left_expr
,
compare_func_creator
func
)
compare_func_creator
func
)
{
{
DBUG_ENTER
(
"Item_in_subselect::single_value_transformer"
);
DBUG_ENTER
(
"Item_in_subselect::single_value_transformer"
);
...
@@ -587,7 +586,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -587,7 +586,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
// 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
;
thd
->
lex
.
current_select
=
up
=
current
->
return_after_parsing
();
thd
->
lex
.
current_select
=
up
=
current
->
return_after_parsing
();
if
(
left_expr
->
fix_fields
(
thd
,
up
->
get_table_list
(),
0
))
if
(
left_expr
->
fix_fields
(
thd
,
up
->
get_table_list
(),
&
left_expr
))
{
{
thd
->
lex
.
current_select
=
current
;
thd
->
lex
.
current_select
=
current
;
DBUG_RETURN
(
RES_ERROR
);
DBUG_RETURN
(
RES_ERROR
);
...
@@ -716,8 +715,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
...
@@ -716,8 +715,7 @@ Item_in_subselect::single_value_transformer(JOIN *join,
}
}
Item_subselect
::
trans_res
Item_subselect
::
trans_res
Item_in_subselect
::
row_value_transformer
(
JOIN
*
join
,
Item_in_subselect
::
row_value_transformer
(
JOIN
*
join
)
Item
*
left_expr
)
{
{
DBUG_ENTER
(
"Item_in_subselect::row_value_transformer"
);
DBUG_ENTER
(
"Item_in_subselect::row_value_transformer"
);
...
@@ -800,16 +798,16 @@ Item_subselect::trans_res
...
@@ -800,16 +798,16 @@ Item_subselect::trans_res
Item_in_subselect
::
select_transformer
(
JOIN
*
join
)
Item_in_subselect
::
select_transformer
(
JOIN
*
join
)
{
{
if
(
left_expr
->
cols
()
==
1
)
if
(
left_expr
->
cols
()
==
1
)
return
single_value_transformer
(
join
,
left_expr
,
return
single_value_transformer
(
join
,
&
Item_bool_func2
::
eq_creator
);
&
Item_bool_func2
::
eq_creator
);
return
row_value_transformer
(
join
,
left_expr
);
return
row_value_transformer
(
join
);
}
}
Item_subselect
::
trans_res
Item_subselect
::
trans_res
Item_allany_subselect
::
select_transformer
(
JOIN
*
join
)
Item_allany_subselect
::
select_transformer
(
JOIN
*
join
)
{
{
return
single_value_transformer
(
join
,
left_expr
,
func
);
return
single_value_transformer
(
join
,
func
);
}
}
subselect_single_select_engine
::
subselect_single_select_engine
::
...
...
sql/item_subselect.h
View file @
abfa5514
...
@@ -210,10 +210,8 @@ class Item_in_subselect :public Item_exists_subselect
...
@@ -210,10 +210,8 @@ class Item_in_subselect :public Item_exists_subselect
}
}
trans_res
select_transformer
(
JOIN
*
join
);
trans_res
select_transformer
(
JOIN
*
join
);
trans_res
single_value_transformer
(
JOIN
*
join
,
trans_res
single_value_transformer
(
JOIN
*
join
,
Item
*
left_expr
,
compare_func_creator
func
);
compare_func_creator
func
);
trans_res
row_value_transformer
(
JOIN
*
join
,
trans_res
row_value_transformer
(
JOIN
*
join
);
Item
*
left_expr
);
longlong
val_int
();
longlong
val_int
();
double
val
();
double
val
();
String
*
val_str
(
String
*
);
String
*
val_str
(
String
*
);
...
...
sql/set_var.cc
View file @
abfa5514
...
@@ -2279,7 +2279,11 @@ int set_var::update(THD *thd)
...
@@ -2279,7 +2279,11 @@ int set_var::update(THD *thd)
int
set_var_user
::
check
(
THD
*
thd
)
int
set_var_user
::
check
(
THD
*
thd
)
{
{
return
(
user_var_item
->
fix_fields
(
thd
,
0
,
(
Item
**
)
0
)
||
/*
Item_func_set_user_var can't substitute something else on its place =>
0 can be passed as last argument
*/
return
(
user_var_item
->
fix_fields
(
thd
,
0
,
(
Item
**
)
0
)
||
user_var_item
->
check
())
?
-
1
:
0
;
user_var_item
->
check
())
?
-
1
:
0
;
}
}
...
...
sql/sql_select.cc
View file @
abfa5514
...
@@ -8525,11 +8525,7 @@ static bool add_ref_to_table_cond(THD *thd, JOIN_TAB *join_tab)
...
@@ -8525,11 +8525,7 @@ static bool add_ref_to_table_cond(THD *thd, JOIN_TAB *join_tab)
if
(
thd
->
is_fatal_error
)
if
(
thd
->
is_fatal_error
)
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
/*
cond
->
fix_fields
(
thd
,(
TABLE_LIST
*
)
0
,
(
Item
**
)
&
cond
);
Here we pass 0 as the first argument to fix_fields that don't need
to do any stack checking (This is already done in the initial fix_fields).
*/
cond
->
fix_fields
((
THD
*
)
0
,(
TABLE_LIST
*
)
0
,
(
Item
**
)
&
cond
);
if
(
join_tab
->
select
)
if
(
join_tab
->
select
)
{
{
error
=
(
int
)
cond
->
add
(
join_tab
->
select
->
cond
);
error
=
(
int
)
cond
->
add
(
join_tab
->
select
->
cond
);
...
...
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