do{}while() 实现上下连号查询

这里写图片描述

    /*
     * 查询来货编号有连号且在未开箱状态
     * 
     * $trackingNumber          String          来货编号
     * $warehouseId             Integer         仓库
     */
    public function whetherConsecutiveNumbers($trackingNumber, $warehouseId) {
        $rpTrackingNumber = $trackingNumber;
        $data = array();
        do {
            $rpIds = $this->getByleftJoin(array('rp_tracking_number' => $trackingNumber, 'warehouse_id' => $warehouseId), '*');
            if ($rpIds && $rpIds[0]['rp_status'] == 0 && !$rpIds[0]['receiving_code']) {
                $trackingNumber = substr($rpIds[0]['rp_tracking_number'], 0, -5) . str_pad((substr($rpIds[0]['rp_tracking_number'], -5) - 1), 5, '0', STR_PAD_LEFT);
                $data[] = $rpIds[0]['rp_tracking_number'];
            } else {
                break;
            }
        } while ($rpIds);
        do {
            $rpIds = $this->getByleftJoin(array('rp_tracking_number' => $rpTrackingNumber, 'warehouse_id' => $warehouseId), '*');
            if ($rpIds && $rpIds[0]['rp_status'] == 0 && !$rpIds[0]['receiving_code']) {
                $rpTrackingNumber = substr($rpIds[0]['rp_tracking_number'], 0, -5) . str_pad((substr($rpIds[0]['rp_tracking_number'], -5) + 1), 5, '0', STR_PAD_LEFT);
                $data[] = $rpIds[0]['rp_tracking_number'];
            } else {
                break;
            }
        } while ($rpIds);
        $return['data'] = array_unique($data);
        sort($return['data']);
        if (count($return['data']) > 1) {
            return $return;
        }
    }

substr — 返回字符串的子串
str_pad — 使用另一个字符串填充字符串为指定长度

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值