sql >> Database teknologi >  >> RDS >> Mysql

Hvordan finder man rækker>kolonnekombinationer med Cross Join? [SQL]

Du kan bruge en cross join og filtrering:

select t1.post_title, t2.post_title, t3.post_title
from t t1 cross join
     t t2 cross join
     t t3
where t1.category_id = 1 and
      t2.category_id = 2 and
      t3.category_id = 3;

Du kan generalisere dette ved at bruge en rekursiv CTE:

with recursive tt as (
      select t.*, dense_rank() over (order by category_id) as cat_seqnum
      from t
     ),
     cte as (
      select cat_seqnum, post_title
      from tt
      where cat_seqnum = 1
      union all
      select  tt.cat_seqnum, concat_ws('-', cte.post_title, tt.post_title)
      from cte join
           tt
           on tt.cat_seqnum = cte.cat_seqnum + 1
     )
select *
from cte
where cat_seqnum = (select max(cat_seqnum) from tt);

Her er en db<>violin.




  1. Hvordan konfigureres Ruby on Rails med Oracle?

  2. Få uforpligtende data i MySQL

  3. Store tabeller og analyser i MySql

  4. Er flere fremmednøgler i et enkelt felt mulige?