返回顶部

收藏

用SQL得到全排列

更多

在表Elements中存放了7个数,要得到这些数的全排列。

--创建Elements表 
create table Elements
(
    i int not null primary key
)
GO
insert into Elements
values (1),(2),(3),(4),(5),(6),(7);

--[SQL]代码
With ElementsWithWeight as
(
    select
        i,
        power(2,(i-1)) as wgt
    from
        Elements
)
select
    E1.i, E2.i, E3.i, E4.i, E5.i, E6.i, E7.i
from
    ElementsWithWeight as E1,
    ElementsWithWeight as E2,
    ElementsWithWeight as E3,
    ElementsWithWeight as E4,
    ElementsWithWeight as E5,
    ElementsWithWeight as E6,
    ElementsWithWeight as E7
where
    (E1.wgt + E2.wgt + E3.wgt + E4.wgt + E5.wgt + E6.wgt + E7.wgt) = 127

--初始化数据
create table users (name char(2),value char(1),id number);
insert into users values('甲','a',1);
insert into users values('乙','b',2);
insert into users values('丙','c',3);
insert into users values('丁','d',4);
commit;

--2个元素全排列
select o.p as "排列" from
  (select replace (sys_connect_by_path( value, ',' ) , ',' ) p
  from users connect by nocycle value != prior value) o
  where length(o.p) =2;

--3个元素全排列
select o.p as "排列" from
   (select replace (sys_connect_by_path( value, ',' ) , ',' ) p
   from users connect by nocycle value != prior value) o
   where length(o.p) =3;

--4个元素全排列
select o.p as "排列" from
   (select replace (sys_connect_by_path( value, ',' ) , ',' ) p
   from users connect by nocycle value != prior value) o
   where length(o.p) =4;
--该片段来自于http://outofmemory.cn

标签:sql,数据库

收藏

0人收藏

支持

0

反对

0

相关聚客文章
  1. H.E. 发表 2010-01-26 14:21:14 SQL语句查询优化测试
  2. dormy 发表 2013-11-21 02:34:49 JNDI连接数据库
  3. wwek 发表 2014-03-16 06:20:27 NoSQL反模式 – 文档数据库篇
  4. 谢权 发表 2016-02-01 17:23:17 SQL入门练习(三)
  5. 博主 发表 2016-12-02 17:36:11 数据库行列转换
  6. 图表大师 发表 2017-04-05 07:18:04 漫画赏析:Linux 版 SQL Server
  7. OuuYoung 发表 2014-09-18 11:32:10 列出数据库所有表名与列
  8. viviworld 发表 2015-06-05 00:38:00 更好的 SQL 模式的 10 条规则
  9. camnpr@163.com (佚名) 发表 2015-12-22 02:46:39 PHP如何执行SQL文件导入到mysql数据库
  10. 刘莉莉 发表 2016-03-19 14:45:05 SQL应用速查手册 : Chapter2 数据库操作实例
  11. 小码哥 发表 2017-07-06 05:33:49 SQL、NewSQL和NoSQL融合研究与实践
  12. shushenghong@gmail.c 发表 2014-09-15 12:32:14 php连接ms sql数据库的一些问题

发表评论