2016-05-08 22:04:41 +02:00
|
|
|
create table t1 (a int, b varchar(32));
|
|
|
|
insert into t1 values
|
|
|
|
(4,'aaaa' ), (7,'bb'), (1,'ccc'), (4,'dd');
|
|
|
|
insert into t1 values
|
|
|
|
(3,'eee'), (7,'bb'), (1,'fff'), (4,'ggg');
|
|
|
|
|
2016-05-10 21:32:02 +02:00
|
|
|
--ERROR ER_RECURSIVE_WITHOUT_ANCHORS
|
2016-05-08 22:04:41 +02:00
|
|
|
with recursive
|
|
|
|
a1(a,b) as
|
|
|
|
(select * from t1 where t1.a>3
|
|
|
|
union
|
|
|
|
select * from b1 where b1.a >3
|
|
|
|
union
|
|
|
|
select * from c1 where c1.a>3),
|
|
|
|
b1(a,b) as
|
|
|
|
(select * from a1 where a1.b > 'ccc'
|
|
|
|
union
|
|
|
|
select * from c1 where c1.b > 'ddd'),
|
|
|
|
c1(a,b) as
|
|
|
|
(select * from a1 where a1.a<6 and a1.b< 'zz'
|
|
|
|
union
|
|
|
|
select * from b1 where b1.b > 'auu')
|
|
|
|
select * from c1;
|
|
|
|
|
|
|
|
drop table t1;
|
|
|
|
|
|
|
|
create table folks(id int, name char(32), dob date, father int, mother int);
|
|
|
|
|
|
|
|
insert into folks values
|
|
|
|
(100, 'Vasya', '2000-01-01', 20, 30),
|
|
|
|
(20, 'Dad', '1970-02-02', 10, 9),
|
|
|
|
(30, 'Mom', '1975-03-03', 8, 7),
|
|
|
|
(10, 'Grandpa Bill', '1940-04-05', null, null),
|
|
|
|
(9, 'Grandma Ann', '1941-10-15', null, null),
|
|
|
|
(25, 'Uncle Jim', '1968-11-18', 8, 7),
|
|
|
|
(98, 'Sister Amy', '2001-06-20', 20, 30),
|
|
|
|
(8, 'Grandma Sally', '1943-08-23', 5, 6),
|
|
|
|
(6, 'Grandgrandma Martha', '1923-05-17', null, null),
|
|
|
|
(67, 'Cousin Eddie', '1992-02-28', 25, 27),
|
|
|
|
(27, 'Auntie Melinda', '1971-03-29', null, null);
|
|
|
|
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
union
|
|
|
|
select p.id, p.name, p.dob, p.father, p.mother
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
union
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Cousin Eddie'
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors as a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' or name='Sister Amy'
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors as a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
prev_gen
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select folks.*
|
|
|
|
from folks, prev_gen
|
|
|
|
where folks.id=prev_gen.father or folks.id=prev_gen.mother
|
|
|
|
union
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name='Vasya'
|
|
|
|
),
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name='Vasya'
|
|
|
|
union
|
|
|
|
select *
|
|
|
|
from ancestors
|
|
|
|
union
|
|
|
|
select *
|
|
|
|
from prev_gen
|
|
|
|
)
|
|
|
|
select ancestors.name, ancestors.dob from ancestors;
|
|
|
|
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
descendants
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Grandpa Bill'
|
|
|
|
union
|
|
|
|
select folks.*
|
|
|
|
from folks, descendants as d
|
|
|
|
where d.id=folks.father or d.id=folks.mother
|
|
|
|
)
|
|
|
|
select * from descendants;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
descendants
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Grandma Sally'
|
|
|
|
union
|
|
|
|
select folks.*
|
|
|
|
from folks, descendants as d
|
|
|
|
where d.id=folks.father or d.id=folks.mother
|
|
|
|
)
|
|
|
|
select * from descendants;
|
|
|
|
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father OR p.id = a.mother
|
|
|
|
)
|
|
|
|
select *
|
|
|
|
from ancestors t1, ancestors t2
|
|
|
|
where exists (select * from ancestors a
|
|
|
|
where a.father=t1.id AND a.mother=t2.id);
|
|
|
|
|
|
|
|
with
|
|
|
|
ancestor_couples(husband, h_dob, wife, w_dob)
|
|
|
|
as
|
|
|
|
(
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya'
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father OR p.id = a.mother
|
|
|
|
)
|
|
|
|
select t1.name, t1.dob, t2.name, t2.dob
|
|
|
|
from ancestors t1, ancestors t2
|
|
|
|
where exists (select * from ancestors a
|
|
|
|
where a.father=t1.id AND a.mother=t2.id)
|
|
|
|
)
|
|
|
|
select * from ancestor_couples;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
2016-05-14 22:33:50 +02:00
|
|
|
where name = 'Vasya'
|
2016-05-08 22:04:41 +02:00
|
|
|
union
|
|
|
|
select p.*
|
2016-05-14 22:33:50 +02:00
|
|
|
from folks as p, ancestors as fa
|
|
|
|
where p.id = fa.father
|
2016-05-08 22:04:41 +02:00
|
|
|
union
|
|
|
|
select p.*
|
2016-05-14 22:33:50 +02:00
|
|
|
from folks as p, ancestors as ma
|
|
|
|
where p.id = ma.mother
|
2016-05-08 22:04:41 +02:00
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
with recursive
|
|
|
|
ancestor_couples(h_id, h_name, h_dob, h_father, h_mother,
|
|
|
|
w_id, w_name, w_dob, w_father, w_mother)
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select h.*, w.*
|
|
|
|
from folks h, folks w, coupled_ancestors a
|
|
|
|
where a.father = h.id AND a.mother = w.id
|
|
|
|
union
|
|
|
|
select h.*, w.*
|
|
|
|
from folks v, folks h, folks w
|
|
|
|
where v.name = 'Vasya' and
|
|
|
|
(v.father = h.id AND v.mother= w.id)
|
|
|
|
),
|
|
|
|
coupled_ancestors (id, name, dob, father, mother)
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select h_id, h_name, h_dob, h_father, h_mother
|
|
|
|
from ancestor_couples
|
|
|
|
union
|
|
|
|
select w_id, w_name, w_dob, w_father, w_mother
|
|
|
|
from ancestor_couples
|
|
|
|
)
|
|
|
|
select h_name, h_dob, w_name, w_dob
|
|
|
|
from ancestor_couples;
|
|
|
|
|
2016-05-12 22:23:12 +02:00
|
|
|
|
|
|
|
prepare stmt1 from "
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
union
|
|
|
|
select p.id, p.name, p.dob, p.father, p.mother
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
";
|
|
|
|
|
|
|
|
execute stmt1;
|
|
|
|
execute stmt1;
|
|
|
|
|
|
|
|
deallocate prepare stmt1;
|
|
|
|
|
|
|
|
|
|
|
|
create view v1 as
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
union
|
|
|
|
select p.id, p.name, p.dob, p.father, p.mother
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
show create view v1;
|
|
|
|
|
|
|
|
select * from v1;
|
|
|
|
|
2016-05-14 22:33:50 +02:00
|
|
|
create view v2 as
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya'
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors as fa
|
|
|
|
where p.id = fa.father
|
|
|
|
union
|
|
|
|
select p.*
|
|
|
|
from folks as p, ancestors as ma
|
|
|
|
where p.id = ma.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
show create view v2;
|
|
|
|
|
|
|
|
select * from v2;
|
2016-05-12 22:23:12 +02:00
|
|
|
|
2016-05-14 22:33:50 +02:00
|
|
|
drop view v1,v2;
|
2016-05-12 22:23:12 +02:00
|
|
|
|
|
|
|
explain extended
|
|
|
|
with recursive
|
|
|
|
ancestors
|
|
|
|
as
|
|
|
|
(
|
|
|
|
select *
|
|
|
|
from folks
|
|
|
|
where name = 'Vasya' and dob = '2000-01-01'
|
|
|
|
union
|
|
|
|
select p.id, p.name, p.dob, p.father, p.mother
|
|
|
|
from folks as p, ancestors AS a
|
|
|
|
where p.id = a.father or p.id = a.mother
|
|
|
|
)
|
|
|
|
select * from ancestors;
|
|
|
|
|
|
|
|
|
2016-05-08 22:04:41 +02:00
|
|
|
drop table folks;
|
|
|
|
|