如何在我的php服务器上获取我的系统时区

时间:2013-09-19 06:48:28

标签: php mysql timezone

我的机器有(GMT +6:00阿斯塔纳,达卡)。我在我的PHP脚本上设置了我的时区

date_default_timezone_set('Asia/Dhaka');

但有时它会在date()函数中显示错误的日期。可能是我的php服务器没有设置GMT时间。

但我的mysql服务器捕获我的机器系统时区。所以我需要在php中使用相同的功能 这里我的数据库表概述了

  SHOP_BALANCE-------------shop_balance_id(PK,AI,INT),shop_balance(DOUBLE),dates(DATE)
  PRODUCT_PURCHASE_ITEM----product_purchase_item_id(PK,AI,INT),product_id(INT),
                           pr_pur_cost_price(DOUBLE),pr_pur_unit_price(DOUBLE),
                           quantity(INT),product_size(INT),dates(TIMESTAMP),
                           bool_check(TINYINT)
  PRODUCT_PURCHASES--------product_purchase_id(PK,AI,INT),insert_operation(INT),
                           product_purchase_item_id(FK ref of PRODUCT_PURCHASE_ITEM).
                           product_id(INT),dates(TIMESTAMP),product_size(INT)
  

IDEA如果日期匹配,在这一天下降平衡。如果日期是新的日期以便在最后一天购物,那么购物平衡也会减少,但是会在新的日期进行,

这是我的代码

在shop_balance表上查找最后一行mysql日期。我的日期列为date类型

$query=$this->db->query("select dates from shop_balance order by dates desc limit 1");
$rowfind_last_stock=$query->row();
if(isset($rowfind_last_stock->dates)){
    $find_last_date=$rowfind_stock->dates;
}

在我的php服务器中找到今天的日期

$today=date("Y-m-d");

检查不同查询的日期

if($find_last_date==$today){
   //run update query 
   $this->db->query(
                   "UPDATE
                      shop_balance AS s
                    INNER JOIN
                    (
                     SELECT p.dates,SUM(pr_pur_cost_price*quantity) AS net 
                     FROM product_purchase_item AS i
                     LEFT JOIN product_purchases AS p
                     ON p.product_purchase_item_id=i.product_purchase_item_id
                     WHERE p.insert_operation='$id'
                     GROUP BY p.insert_operation
                    ) AS a
                    ON s.dates=date(a.dates)
                    SET s.shop_balance=s.shop_balance-a.net
                  );"
}
else{
 //run insert query
 $this->db->query(
                   "INSERT INTO shop_balance 
                      SELECT null,
                      (
                       (
                        SELECT shop_balance 
                        FROM shop_balance 
                        ORDER BY shop_balance_id 
                        DESC LIMIT 1
                       )
                      -
                       (
                        SELECT p.dates,SUM(pr_pur_cost_price*quantity) AS net 
                        FROM product_purchase_item AS i
                        LEFT JOIN product_purchases AS p
                        ON p.product_purchase_item_id=i.product_purchase_item_id
                        WHERE p.insert_operation='$id'
                        GROUP BY p.insert_operation             
                       )
                     ),
                     curdate();"
                 );
}

问题是,当我安装不同时,它甚至在php和mysql日期执行插入查询甚至相同的日期。我在GMT +6.00以上设置的时区。为什么会出现这个问题呢?

5 个答案:

答案 0 :(得分:1)

请参阅文档MySQL Server Time Zone Support以及time_zonesystem_time_Zone变量。

我相信您会发现您的系统时区设置不符合您的预期。当您的插入查询调用curdate()时,MySQL会在会话的time_zone变量的时区内传递它。默认情况下,这将与system_time_zone变量中设置的区域相同。

您可以像这样检查您的时区变量:

SHOW VARIABLES LIKE '%time_zone'

如果您不想更改MySQL服务器的系统时区,则可以在查询之前插入此区域来设置会话时区:

SET time_zone = 'Asia/Dhaka';

如果收到错误,则表示尚未加载时区表。您可以使用mysql_tzinfo_to_sql填充它们。另请参阅this answer

当然,更简单的解决方案是不使用curdate(),而是从PHP收集当前日期并将其作为参数传递给查询。

答案 1 :(得分:0)

我正在使用此功能。

function currentDate($dateOnly = false, $tillEnd = false)
    {
        // gmmktime(0, 0, 0, 7, 1, 2000) H i s m d Y
        if($dateOnly)
        {
            if($tillEnd)
            {
                $t = explode('-',date('Y-m-d'));
                return date('Y-m-d',mktime(23, 59, 59, $t[1], $t[2],$t[0]));
            }else{
                return date('Y-m-d');
            }
        }else{
            if($tillEnd)
            {
                $t = explode('-',date('Y-m-d'));
                return date('Y-m-d H:i:s',mktime(23, 59, 59, $t[1], $t[2],$t[0]));
            }else{
                return date('Y-m-d H:i:s');
            }
        }
    }

您可以调用此函数来获取系统的时间。 参数是可选的,如果您想获得当前日期的时间,请拨打为 例如:

$currentDatetime=currentDate();

答案 2 :(得分:0)

请注意,由于PHP 5.1.0(重写date/time函数时),如果时区无效,每次调用date/time函数都会生成E_NOTICE,和/或E_WARNING消息,如果使用系统设置或TZ环境变量。

您可以使用INI设置date.timezone设置默认时区,而不是使用此功能在脚本中设置默认时区。

答案 3 :(得分:-1)

<强> time()

通过这个你可以获得系统的时间

Manual

答案 4 :(得分:-1)

试试这个

<?php
$date = new DateTime(null, new DateTimeZone('Europe/London'));
$tz = $date->getTimezone();
echo $tz->getName();
?>