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
900a6296
Commit
900a6296
authored
Sep 10, 2004
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
view with WHERE in nested join (BUG#5511)
parent
c2f65221
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
53 additions
and
9 deletions
+53
-9
mysql-test/r/view.result
mysql-test/r/view.result
+23
-0
mysql-test/t/view.test
mysql-test/t/view.test
+13
-0
sql/table.cc
sql/table.cc
+17
-9
No files found.
mysql-test/r/view.result
View file @
900a6296
...
@@ -1288,3 +1288,26 @@ handler v1 open as xx;
...
@@ -1288,3 +1288,26 @@ handler v1 open as xx;
ERROR HY000: 'test.v1' is not BASE TABLE
ERROR HY000: 'test.v1' is not BASE TABLE
drop view v1;
drop view v1;
drop table t1;
drop table t1;
create table t1(a int);
insert into t1 values (0), (1), (2), (3);
create table t2 (a int);
insert into t2 select a from t1 where a > 1;
create view v1 as select a from t1 where a > 1;
select * from t1 left join (t2 as t, v1) on v1.a=t1.a;
a a a
0 NULL NULL
1 NULL NULL
2 2 2
2 3 2
3 2 3
3 3 3
select * from t1 left join (t2 as t, t2) on t2.a=t1.a;
a a a
0 NULL NULL
1 NULL NULL
2 2 2
2 3 2
3 2 3
3 3 3
drop view v1;
drop table t1;
mysql-test/t/view.test
View file @
900a6296
...
@@ -1258,3 +1258,16 @@ create view v1 as select * from t1;
...
@@ -1258,3 +1258,16 @@ create view v1 as select * from t1;
handler
v1
open
as
xx
;
handler
v1
open
as
xx
;
drop
view
v1
;
drop
view
v1
;
drop
table
t1
;
drop
table
t1
;
#
# view with WHERE in nested join
#
create
table
t1
(
a
int
);
insert
into
t1
values
(
0
),
(
1
),
(
2
),
(
3
);
create
table
t2
(
a
int
);
insert
into
t2
select
a
from
t1
where
a
>
1
;
create
view
v1
as
select
a
from
t1
where
a
>
1
;
select
*
from
t1
left
join
(
t2
as
t
,
v1
)
on
v1
.
a
=
t1
.
a
;
select
*
from
t1
left
join
(
t2
as
t
,
t2
)
on
t2
.
a
=
t1
.
a
;
drop
view
v1
;
drop
table
t1
;
sql/table.cc
View file @
900a6296
...
@@ -1583,6 +1583,7 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
...
@@ -1583,6 +1583,7 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
if
(
where
)
if
(
where
)
{
{
Item_arena
*
arena
=
thd
->
current_arena
,
backup
;
Item_arena
*
arena
=
thd
->
current_arena
,
backup
;
TABLE_LIST
*
tbl
=
this
;
if
(
arena
->
is_conventional
())
if
(
arena
->
is_conventional
())
arena
=
0
;
// For easier test
arena
=
0
;
// For easier test
...
@@ -1591,17 +1592,23 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
...
@@ -1591,17 +1592,23 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
if
(
arena
)
if
(
arena
)
thd
->
set_n_backup_item_arena
(
arena
,
&
backup
);
thd
->
set_n_backup_item_arena
(
arena
,
&
backup
);
if
(
outer_join
)
/* Go up to join tree and try to find left join */
for
(;
tbl
;
tbl
=
tbl
->
embedding
)
{
{
/*
if
(
tbl
->
outer_join
)
Store WHERE condition to ON expression for outer join, because we
{
can't use WHERE to correctly execute jeft joins on VIEWs and this
/*
expression will not be moved to WHERE condition (i.e. will be clean
Store WHERE condition to ON expression for outer join, because we
correctly for PS/SP)
can't use WHERE to correctly execute jeft joins on VIEWs and this
*/
expression will not be moved to WHERE condition (i.e. will be clean
on_expr
=
and_conds
(
on_expr
,
where
);
correctly for PS/SP)
*/
on_expr
=
and_conds
(
tbl
->
on_expr
,
where
);
break
;
}
}
}
else
if
(
tbl
==
0
)
{
{
/*
/*
It is conds of JOIN, but it will be stored in st_select_lex::prep_where
It is conds of JOIN, but it will be stored in st_select_lex::prep_where
...
@@ -1609,6 +1616,7 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
...
@@ -1609,6 +1616,7 @@ bool st_table_list::setup_ancestor(THD *thd, Item **conds)
*/
*/
*
conds
=
and_conds
(
*
conds
,
where
);
*
conds
=
and_conds
(
*
conds
,
where
);
}
}
if
(
arena
)
if
(
arena
)
thd
->
restore_backup_item_arena
(
arena
,
&
backup
);
thd
->
restore_backup_item_arena
(
arena
,
&
backup
);
}
}
...
...
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