### 訂單唯一碼表訂單SKU表實收金額之生成的開發示例
* [ ] 第一步>>訂單SKU表存入SKU相關信息
```
這里SKU的實收金額小計字段先不存,這個待會再解釋原因
```
* [ ] 第二步>>訂單唯一碼表存入唯一碼相關信息
**單品實收金額計算邏輯**
~~~
商品銷售金額總和 = 訂單應收總金額 + 滿減滿折活動優惠金額
每個唯一碼的實收金額 = 訂單實收總金額 * (銷售價/商品銷售金額總和)
即:根據單品的銷售價在商品銷售總金額中的比例,乘以訂單實收總金額,分攤計算單個商品的實收金額
~~~
可調用OrderLib組件庫中的
calculatePayinAmount方法
**大致代碼結構如下:**
~~~
$my_order = new OrdersLib(); // 實例化組件庫
// 商品銷售金額總和 = 訂單應收總金額 + 滿減滿折活動優惠金額
$ac_total = $order_data['receivable_amount'] + $order_data['total_event_amount'];
foreach ( 訂單唯一碼信息數組 as $key => $value) {
...
單個唯一碼的實收金額 = $my_order->calculatePayinAmount($order_data['pay_amount'], $vv['ac_price'], $ac_total);
...
...保存單條唯一碼信息...
...
}
~~~
***
# *敲黑板,重點來了*
用此方法計算的單品唯一碼實收金額四舍五入保留了兩位有效數字,因此所有的單品的實收金額之和可能訂單實收金額存在小數精度的誤差
**!!!所以生成訂單還需要下面的步驟來校驗并修正這個誤差!!!**
***
* [ ] 第三步>>修正訂單唯一碼實收金額之和與訂單實收金額不相等的誤差
~~~
1.查詢訂單唯一碼信息
2.計算訂單中所有唯一碼的實收金額之和
3.比較訂單實收金額和唯一碼實收金額之和的誤差
4.如果存在誤差,在訂單的第一個唯一碼的實收金額上加上誤差值來修正
~~~
可調用OrderLib組件庫中的
correctPayinAmount方法
**代碼示例**
~~~
// 修正訂單唯一碼實收金額之和與訂單實收金額不相等的誤差
$my_correct = $my_order->correctPayinAmount($order_id);
// 如果修正失敗回滾事務,拋出錯誤信息
if (!$my_correct) {
M()->rollback();
$result = array('success' => false, 'code' => 5014, 'msg' => '修正唯一碼誤差失敗!');
return $result;
}
~~~
* [ ] 第四步>>補全訂單SKU表的小計字段
~~~
1.查詢訂單SKU信息
2.遍歷SKU信息,依次查詢每個SKU在該訂單中的唯一碼
3.將各SKU下的所有唯一碼分別加和計算出SKU的價格信息
~~~
*****
## 這里之所以不在第一步用唯一碼的實收金額乘以購買商品的數量來計算小計,是因為唯一碼表中的實收金額可能經過了第三步校驗,同一個SKU存在兩種不一樣的價格,用乘法算出的各SKU小計加起來和訂單實收金額也會存在誤差!!!
*****
**代碼示例**
~~~
// 填充訂單SKU表的小計字段
$my_cal = $my_order->calculateSubtotal($order_id);
// 如果修正失敗回滾事務,拋出錯誤信息
if (!$my_cal) {
M()->rollback();
$result = array('success' => false, 'code' => 5015, 'msg' => '累加補全訂單SKU表小計字段失敗!');
return $result;
}
~~~
- 模版
- 前言
- 項目架構
- 項目規范
- HTML
- CSS
- Javascript
- PHP
- MySQL
- 注意規范
- 開發版本管理
- 開發流程
- 系統配置
- 阿里云服務器配置
- 計劃任務配置說明
- 開發示例
- Page分頁
- Search_param搜索結果賦值
- Add新增
- Edit編輯
- Ajax表單驗證
- Ajax二級聯動
- Excel 導出數據首位不去0的方法
- POS總部控制
- 下載CSV格式的模板
- 訂單唯一碼表和訂單SKU表實收金額生成
- 快捷日期選擇
- JS函數
- ajax_send
- ajax_result
- createQrCodes
- createBarCodes
- printTpl
- JS插件
- BootstrapValidator表單驗證插件
- Address省市區插件
- Bootstrap-datepicker日期插件
- Bootstrap-select多選框插件
- Toastr消息提示插件
- PalyAudit掃描聲音提示插件
- WebUploader多圖片上傳插件
- Ueditor富文本編輯器插件
- Function
- alert
- object_to_array
- array_to_object
- get_address
- set_param_url
- get_shops_name
- get_user_name
- get_warehouse
- get_cheapest_sku
- print_attr(新)
- print_img(新)
- get_spu_no(新)
- get_type_name(新)
- get_brand_en(新)
- get_cat_name(新)
- get_attr_name(新)
- spu_cat_info(新)
- get_time_event_price
- get_vendors
- check_total_reduce
- check_total_discount
- get_inventory
- get_delivery
- get_sale_inventory
- get_customer_name
- phone_protection
- get_order_no
- get_event_name
- get_order_status
- get_item_status
- get_ditch_name
- get_card_no
- get_shop_sales
- get_pay_name
- get_season
- amt_format
- get_cat_parent
- print_attr_id
- round_bcadd
- round_bcsub
- round_bcmul
- round_bcdiv
- get_account_name
- Controller
- Common_BaseController
- check_membership_card
- get_menu_list
- importErrorMassage
- Wpos_IndexController
- get_customer_vip_card
- get_shops_id
- calculate_active_integral
- check_numbers_active
- check_goods_active
- Woms_IndexController
- Model
- View
- category
- cycle_date.html
- shop_select門店多選搜索框
- 品牌A-Z排序多選brand_mc.html
- 供應商代碼A-Z排序vendor_no_mc.html
- Lib
- BuyerLib
- WarehouseLib
- EventLib
- getTimeEventPrice
- getVipType
- getEvent
- orderTotalEvent
- orderTimeEvent
- getTotalReduce
- getTotalDiscount
- SaleLib
- CustomerLib
- addCustomerService
- GiftcardLib
- WechatLib
- wxRefund
- OrdersLib
- orderLog
- calculatePayinAmount
- calculateSubtotal
- correctPayinAmount
- saveOrderAddress
- getOrderAddress
- setDeliveryNo
- SyncLib
- updateOuterStock
- UserLib
- createCommission
- FlowLib
- orderList
- addOrder
- addLog
- orderInfo
- checkSku
- orderSave
- orderStop
- orderExecute
- skuEdit
- orderPrinta
- scanGoods
- boxClose
- orderOut
- take
- bview
- check
- deliveryStatus
- checkGoods
- GoodsLib
- createGoodsNo
- createNewGoodsNo
- getSystemStyleNo
- getDim
- MallLib
- smsLog
- GoodsBaseLib
- getBrandInfo
- getBrandsInfo
- getAttrIdArray
- getPrintAttr
- getMustAttr
- getCatIdInfo
- valTypeId
- valsTypeId
- getCatNoInfo
- getCatInfo
- getAttrArr
- getAttrInfo
- getValInfo
- getAttrId
- getValId
- getAttrSeaon
- getValueId
- PointsLog
- pointsIn
- pointsUp
- EcGoodsLib
- getSkuInventory
- Tools
- CsvTools
- csvImport
- csvExport
- ExcelTools
- importExcel
- exportExcel
- exportHeadExcel
- MailTools
- SmsTools
- sendMessage
- UploadTools
- ExportTools
- exportData
- TaobaoTools
- getOnsaleItems
- getSkusItems
- PicturesTools
- uploadPicture
- Plugins
- WxBase
- Taobao
- 問題反饋