Ejemplo n.º 1
0
 /**
  * 确认表所放的位置
  *
  * @param $billno	单据号
  * @param $data  	数据 array("station"=>,"code"=>)
  * @return boolean
  */
 public function confirmInstation($billdata, $data)
 {
     $sysno = $billdata['sysno'];
     $billdate = $billdata['billDate'];
     //明细表
     $stocks = new StocksDao();
     $stocks->startTrans();
     //当前库存表
     $current = new CurrentStocksDao();
     $current->startTrans();
     //未确认表位
     $unconfirm = new UnconfirmstationDao();
     $unconfirm->startTrans();
     try {
         $newinsert = false;
         $station = $data["station"];
         $code = $data["code"];
         $result = $current->findAll("`code`='{$code}'")->toResultSet();
         if (sizeof($result) == 0 && NOBILL_SCAN == false) {
             $stocks->rollback();
             $current->rollback();
             $unconfirm->rollback();
             $this->setError("库存里找不到该条码[{$code}]对应的表计!");
             return false;
         } else {
             if (sizeof($result) == 0) {
                 $newinsert = true;
                 $codeinfo = new CodeInfo();
                 $codedetail = $codeinfo->getInfoByCode($code);
                 $vo = $stocks->createVo('add', '', 'id', 0, $codedetail);
                 $vo->id = 0;
                 $vo->inoutType = 'IN';
                 $vo->code = $code;
                 $vo->sysno = $billdata['sysno'];
                 $vo->placeno = $billdata['placeno'];
                 $vo->place = $billdata['place'];
                 $vo->billType = $billdata['billType'];
                 $vo->billDate = $billdata['billDate'];
                 $vo->billNo = $billdata['billNo'];
                 $vo->sendMan = $billdata['sendMan'];
                 $vo->saveMan = $billdata['saveMan'];
                 $vo->orderNo = $billdata['orderNo'];
                 $vo->client = $billdata['client'];
                 $vo->inqty = 1;
                 $vo->outqty = 0;
                 $vo->station = $station;
                 //inert new records
                 $stocksmanageraction = new StocksManagerAction();
                 $savedata["modify"] = array($vo->toArray());
                 $result = $stocksmanageraction->save($savedata);
                 if (!$result) {
                     system_out("create new recod error:" . $stocksmanageraction->getError());
                     $this->setError($stocksmanageraction->getError());
                     return false;
                 }
             }
         }
         $sql = "UPDATE " . (DB_PREFIX ? DB_PREFIX . "_" : "") . "currentstocks\n\t\t\t           SET `station`='{$station}'\n\t\t\t\t\t WHERE `code` ='{$code}'";
         system_out("update sql:" . $sql);
         $current->execute($sql);
         if (!$newinsert) {
             //返写stocks
             $result = StocksIndexAction::getTableNameByDate($billdate);
             if ($result == '') {
                 $stocks->rollback();
                 $current->rollback();
                 $unconfirm->rollback();
                 system_out("get tablename error,billdate:" . $billdate);
                 $this->setError("获取存储表出错!");
                 return false;
             }
             $tablename = $result;
             $sql = "UPDATE\t`{$tablename}`\n\t\t\t\t\t\t   SET `station` = '{$station}'\n\t\t\t\t\t\t WHERE `code` = '{$code}' and\n\t\t\t\t\t\t \t\t`sysno` = '{$sysno}' ";
             $stocks->execute($sql);
         }
         //标记已经确认的开灯记录
         $sql = "UPDATE " . (DB_PREFIX ? DB_PREFIX . "_" : "") . "unconfirmstation\n\t\t\t           SET  `confirm` = 1\n\t\t\t\t\t WHERE  `station` = '{$station}' and `state`='U'";
         $unconfirm->execute($sql);
     } catch (Exception $e) {
         $stocks->rollback();
         $current->rollback();
         $unconfirm->rollback();
         system_out("UnconfirmstationAction.confirmInstation error:{$e},\n\t\t\t\t\t\tsysno:{$sysno},data:" . print_r($data, true));
         throw new Exception($e);
     }
     //commit
     $stocks->commit();
     $current->commit();
     $unconfirm->commit();
     return true;
 }
Ejemplo n.º 2
0
 /**
  * 清理数据
  *
  * @param array $cleardata 要清理的类型
  */
 public function clear($cleardata)
 {
     if (!is_array($cleardata)) {
         return "数据清理失败";
     }
     try {
         for ($i = 0; $i < sizeof($cleardata); $i++) {
             $datatype = $cleardata[$i];
             switch ($datatype) {
                 case '采购申请':
                     $dao = new PurchaseOrderHeadDao();
                     $dao->deleteAll('');
                     $dao = new PurchaseOrderDetailDao();
                     $dao->deleteAll('');
                     break;
                 case '客户资料':
                     $dao = new ClientsDao();
                     $dao->deleteAll('');
                     break;
                 case '故障登记':
                     $dao = new FaultLogsDao();
                     $dao->deleteAll('');
                     break;
                 case '定期检查':
                     $dao = new CheckLogsDao();
                     $dao->deleteAll('');
                     break;
                 case '投诉登记':
                     $dao = new ComplaintLogsDao();
                     $dao->deleteAll('');
                     break;
                 case '产品资料':
                     $dao = new GoodsDao();
                     $dao->deleteAll('');
                     break;
                 case '厂商资料':
                     $dao = new SupplyDao();
                     $dao->deleteAll('');
                     break;
                 case '库房资料':
                     $dao = new StorageDao();
                     $dao->deleteAll('');
                     break;
                 case '库存资料':
                     $dao = new StocksIndexDao();
                     $result = $dao->findAll()->toResultSet();
                     for ($j = 0; $j < sizeof($result); $j++) {
                         $tablename = $result[$j]['tablename'];
                         $dao->deleteAll('', $tablename);
                     }
                     $dao->deleteAll('', 'stc_currentstocks');
                     $dao->deleteAll('', 'stc_codeIndex');
                     break;
                 case '条码规则':
                     $dao = new CodeDictDao();
                     $dao->deleteAll('');
                     break;
                 case '开灯记录':
                     $dao = new UnconfirmstationDao();
                     $dao->deleteAll('');
                     break;
             }
         }
     } catch (Exception $e) {
         throw new Exception($e);
     }
     return true;
 }