ferrero项目记录
1、序列码上显示from to
form to 来自于custom,以及其他的比如工厂 RDC
设置的时候都是code,展示的需要展示name。
并且一个name 可能有多个code
设置一张表loction进行维护,custon数据过来的时候 获取其中的code 和name save到loction表
code 设置唯一索引。
然后展示的时候,根据code去查询name即可
2、根据发货地查询
d
这个入库单过来的时候,发货地 from存储的是code,展示的时候是name。
所以搜索的时候将name转换成code,根据code去表里查询。并且一个name可能有多个code,
所以根据name查询到多个code,然后 in 查询即可。
如果一开始就知道所有的code,存储入库单的时候就可以存储code 和name 这样可以直接查询入库单表
List<String> codes = getlocCode(param.getFrom()); String snListString = codes.stream().collect(Collectors.joining(",")); log.info("code="+snListString); query.addCriteria(Criteria.where("from").in(codes)); private List<String> getlocCode(String name){ List<Location> byName = locationRepository.findByName(name); List<String> codes = byName.stream().map(Location::getName).collect(Collectors.toList()); if(ListUtil.isNotEmpty(codes)){ return codes; }else{ log.info("根据name"+name+"未查询到Loc"); List<String> names = new ArrayList<>(); names.add(name); return names; } }
3、
查询订单的批次。。
我都能查错。。细心点一个个的查。double check 一下
3、数据导出不一致,只根据单号导出 和用时间以及RDC导出数据发现数据不一致
原因是因为根据单号导出的时候只根据单号,但是根据时间查询的时候 不仅仅是单号也会查from 才会查询到,导致两边数据不一致
应该按照时间查询,也只查询单号。
5、做一个复杂的功能,一定要细心地测试
做的时候也要多思考,确保逻辑准确性
不然随便测试一下,觉得ok了,然后上线,粗线问题。更加麻烦。
影响效率,影响心情。
做导出报表,DN号,有位置,from to,我用的是SN里的from to 其实就错了,应该是订单里的
sku 数据很多但是其中只有部分是需要我们维护的,然后我竟然用了两个字段去判断是否是我们维护的。
和客户说一个东西ok了,起码自己先看一下有没有问题,别直接说ok了,但是一打开却又问题
【执行顺序问题导致bug】
需要统计HU的数量,查询语句
db.getCollection('serialNumber').count({"parentSn":"01400916113122802110180470936746","toLocation":"MATU","aggreLevelName":"Carton"})
查询结果都是0,但是根据数据来看不应该是0.
最后发现问题了,因为再我查询结果之后,才做了修改sn的to为MATU,所以查询的时候数据都是0。跳转数据即可。
不然看数据库发现数据是对的,为啥查询不出来。。结合逻辑