yufan8410 2015-04-03 00:38 采纳率: 0%
浏览 1795

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

原始需求:这是个仓库自动入库策略, 共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 2015-04-03 01:15
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大