问题描述
- 两个表各自排序后再按权重合并后排序问题?求高手指点,谢谢.在线等。。
-
原始需求:这是个仓库自动入库策略, 共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 字段2a 23
b 16
c 32
d 0
e 26
f 39表a查询结果排序:
字段1 字段2d 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主要是为了求这个排序结果. 求指导,谢谢。。
解决方案
你得说明是什么数据库,像oracle有rownum,按照各表排序后,再union 全sum(rownum)就是你想要的结果
解决方案二:
当然可以用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