yufan8410
yufan8410
采纳率0%
2015-04-03 00:38 阅读 1.8k

两个表各自排序后再按权重合并后排序问题?求高手指点,谢谢.在线等。。

原始需求:这是个仓库自动入库策略, 共6台堆垛机(字段1),同时入库工作,要求根据入库物料在各堆垛机的分布数量,平均分布入库,同时考虑堆垛机入库任务数和繁忙程度。(对物料分布(字段2)查询的结果(如表a查询结果排序)和堆垛机任务数(字段3)查询的结果(表b查询结果排序)分别作比重排序(例如物料分布排序1-6,任务数量排序1-6,两者相加最后综合排序1-6)找出需要入库的堆垛机。)

实现:

表a和表b是2个不同的表,通过字段1关联,分别统计的结果是字段2和字段3(字段2和字段3是不同的字段,比如一个是物料数一个是任务数),将统计的结果分别排序,然后再按照排序的结果分别赋予顺序权重值1-6,然后根据字段1将2者合并求出最后的权重顺序。请高手帮忙啊,如何通过存储过程或sql实现???(注意:要求的结果不能直接是两者合并排序,而是各自排序后求得顺序权重值后再合并排序)

表a
字段1 字段2

a 23
b 16
c 32
d 0
e 26
f 39

表a查询结果排序:
字段1 字段2

d 0
b 16
a 23
e 26
c 32
f 39

表b
字段1 字段3
a 10
b 13
c 23
d 11
e 0
f 28

表b查询结果排序:
字段1 字段3
e 0
a 10
d 11
b 13
c 23
f 28

要求结果:
根据排序后的结果将字段1按顺序赋予权重值(权重值是1-6),从小到大:
a表字段1排序赋予权重后:
字段1 权重
d 1
b 2
a 3
e 4
c 5
f 6
B表字段1排序赋予权重后:
字段1 权重
e 1
a 2
d 3
b 4
c 5
f 6
然后将两个结果合并求和排序,按从小到大:
结果如下:
d 4
a 5
e 5
b 6
c 10
f 12

主要是为了求这个排序结果. 求指导,谢谢。。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

2条回答 默认 最新

  • danielinbiti danielinbiti 2015-04-03 01:15

    你得说明是什么数据库,像oracle有rownum,按照各表排序后,再union 全sum(rownum)就是你想要的结果

    点赞 评论 复制链接分享
  • danielinbiti danielinbiti 2015-04-03 03:27
    当然可以用rownum,也可以用row_number()方式
     CREATE TABLE TEST_A(
       field1 varchar(20),
       nums int default 0
    );
    CREATE TABLE TEST_B(
       field1 varchar(20),
       nums int default 0
    );
    insert into TEST_A(field1,nums) values('a','29');
    insert into TEST_A(field1,nums) values('b','5');
    insert into TEST_A(field1,nums) values('d','13');
    insert into TEST_A(field1,nums) values('d','2');
    
    insert into TEST_B(field1,nums) values('c','2');
    insert into TEST_B(field1,nums) values('e','51');
    insert into TEST_B(field1,nums) values('f','3');
    insert into TEST_B(field1,nums) values('d','26');
    
    select field1,sum(rn) rn from
    (
    select a.*,rownum as rn from (select * from TEST_A order by nums) a 
    union
    select b.*,rownum as rn from (select * from TEST_B order by nums) b
    ) group by field1 order by rn
    
    点赞 评论 复制链接分享

相关推荐