當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DB::beginTransaction方法代碼示例

本文整理匯總了PHP中app\DB::beginTransaction方法的典型用法代碼示例。如果您正苦於以下問題:PHP DB::beginTransaction方法的具體用法?PHP DB::beginTransaction怎麽用?PHP DB::beginTransaction使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在app\DB的用法示例。


在下文中一共展示了DB::beginTransaction方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: finalizePurchaseOrder

 public function finalizePurchaseOrder($poId)
 {
     $returnData = [];
     try {
         \DB::beginTransaction();
         // Mark completed field for all work orders for this PO
         WorkOrder::where('purchase_order_id', $poId)->update(['completed' => 1]);
         // Get all work orders for this PO
         $workOrderIds = WorkOrder::where('purchase_order_id', $poId)->select(['id'])->get();
         // Get all WorkOrderTask statuses
         $workOrderTaskIds = WorkOrderTask::select(['id'])->where('active', 1)->get();
         foreach ($workOrderIds as $woId) {
             // Delete all existing progress rows first
             WorkOrderProgress::where('work_order_id', $woId)->delete();
         }
         /*
         foreach($workOrderIds as $woId)
         {
             // Create full set of statuses for this work order
             foreach($workOrderTaskIds as $woTaskId)
             {
                 WorkOrderProgress::create([
                     'work_order_id' => $woId,
                     'work_order_task_id' => $woTaskId
                 ]);
             }
         }
         */
         // Future PO finalization stuff goes here.
         \DB::commit();
         //return $returnData;
     } catch (\Exception $ex) {
         \DB::rollBack();
         throw $ex;
     }
 }
開發者ID:breenyoung,項目名稱:wfadmin,代碼行數:36,代碼來源:OrderLogicService.php

示例2: doImport

 public function doImport(ProductImportOptions $pio)
 {
     //\Storage::disk('local')->getDriver()->getAdapter()->getPathPrefix()
     $path = $pio->getUuid() . '/' . $pio->getFileName();
     $fileContents = \Storage::disk('imports')->get($path);
     $csv = Reader::createFromString($fileContents);
     $csv->setDelimiter(',');
     if ($pio->isIncludeHeaders()) {
         $csv->setOffset(1);
         //because we don't want to insert the header
     }
     $recordsAdded = 0;
     $recordsUpdated = 0;
     $recordsFailed = 0;
     $recordCount = 0;
     $uploader = new UploadHandler();
     $csv->each(function ($row) use(&$pio, &$recordsAdded, &$recordsUpdated, &$recordsFailed, &$recordCount, &$uploader) {
         /* Row Structure
          *
          *CSV row format:
          *
          * Main,
          * Sub1,
          * Sub2,
          * Description,
          * Brand,
          * Pack,
          * Size,
          * UOM,
          * MPC,
          * Contact,
          * GTIN,
          * Halal,
          * IsOrganicProduct,
          * KosherClassification,
          * CalculationSize,
          * CalculationSizeUnitofMeasure,
          * Calories,
          * CaloriesfromFat,
          * Protein,
          * Carbohydrates,
          * TotalDietaryFibre,
          * TotalSugar,
          * TotalFat,
          * SaturatedFat,
          * Sodium mg,
          * AllergenPeanuts,
          * AllergenTreeNuts,
          * AllergenMilk,
          * AllergenLactose,
          * AllergenEggs,
          * AllergenFish,
          * AllergenShellfish,
          * AllergenSoy,
          * AllergenGluten,
          * Image URL,
          * ItemDetail,
          * Preparation,
          * IngredientsEnglish,
          * BenefitsEnglish
          *
          */
         if ($row[0] != null) {
             if (!$pio->isSimulate()) {
                 \DB::beginTransaction();
             }
             try {
                 // Check to see if the record already exists (update) if not ignore existing items
                 //$product = \App\Models\Product::where('uniquekey', '=', $row[8])
                 //                ->orWhere('uniquekey', '=', $row[11])->first();
                 $isExisting = false;
                 //if(!is_null($product) && isset($product))
                 //{
                 //$isExisting = true;
                 //}
                 if ($isExisting && !$pio->isSimulate() && !$pio->isIgnoreExisting()) {
                     // Clear any existing categories
                     //\DB::table('product_categories')->where('product_id', '=', $product->id)->delete();
                     // Clear any existing allergens
                     //\DB::table('product_allergens')->where('product_id', '=', $product->id)->delete();
                 } else {
                     $product = new \App\Models\Product();
                     $product->vendor_id = $pio->getVendorId();
                     $product->uniquekey = isset($row[8]) ? $row[8] : $row[11];
                     // MPC or GTIN
                 }
                 $product->name = ucfirst(mb_strtolower($row[3]));
                 $product->brand = ucfirst(mb_strtolower($row[4]));
                 $product->pack = $row[5];
                 $product->size = $row[6];
                 $product->uom = $row[7];
                 $product->serving_size_uom = $row[7];
                 // Not sure this should be duplicated
                 $product->mpc = $row[8];
                 $product->broker_contact = $row[9];
                 $product->gtin = $row[10];
                 $product->is_halal = $this->normalizeTrueFalseField($row[11]);
                 $product->is_organic = $this->normalizeTrueFalseField($row[12]);
                 $product->is_kosher = $this->normalizeTrueFalseField($row[13]);
                 $product->calc_size = $row[14];
//.........這裏部分代碼省略.........
開發者ID:gabwhite,項目名稱:fsh,代碼行數:101,代碼來源:CsvProductImporter.php


注:本文中的app\DB::beginTransaction方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。