[英]difference with timezone in Custom Report Magento
我正在Magento中創建自定義報告。 我的服務器位於美國,我的店鋪是巴西人。 事實證明,購買時間表保存在美國時間表中,即比巴西多3小時。 這給報告結果帶來了不同。
想象一下以下情況:客戶在30/06下午10:00(巴西時間)進行購買,在數據庫中,此購買時間為01/07上午01:00。
您如何選擇訂單創建時間(GMT USA)並從巴西順時針轉動?
今天,我正在使用它。
$to="";
$from="";
$show_order_statuses = 0;
$orserstatus = "";
$result_order = 0;
if(!empty($_REQUEST['from']) && !empty($_REQUEST['to'])){
$orders_row = array();
date_default_timezone_set('America/Sao_Paulo'); //define o timezone como Sãp Paulo
$filter_type = $_REQUEST['filter_type'];
$from = $_REQUEST['from'];
$to = $_REQUEST['to'];
$from_date = date('Y-m-d' . ' 00:00:00', strtotime($from));
$to_date = date('Y-m-d' . ' 23:59:59', strtotime($to));
$filter_model = ($filter_type == 'shipping_date')
? 'sales/order_shipment_collection'
: 'sales/order_collection';
if($_REQUEST['show_order_statuses']>0){
$orserstatus = $_REQUEST['order_statuses'];
$_orderCollections = Mage::getResourceModel($filter_model);
$_orderCollections->addAttributeToSelect('*');
$_orderCollections->addFieldToFilter('created_at', array('from'=>$from_date, 'to'=>$to_date));
if($filter_type == 'order_date'){
$_orderCollections->addFieldToFilter('status', $orserstatus);
}
$_orderCollections->setOrder('created_at', 'desc');
$_orderCollections->load();
}else{
$_orderCollections = Mage::getResourceModel($filter_model)
->addAttributeToSelect('*')
->addFieldToFilter('created_at', array('from'=>$from_date, 'to'=>$to_date))
->setOrder('created_at', 'desc')
->load();
}
有人可以提供幫助,謝謝
您應該始終使用Magento的核心日期函數來計算時區。
所以代替:
$from_date = date( 'Y-m-d' . ' 00:00:00', strtotime( $from ) );
采用:
$from_date = Mage::getModel( 'core/date' )->date( 'Y-m-d 00:00:00', strtotime( $from ) );
這將根據您在管理中的商店配置中設置的時區為您提供日期。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.