簡體   English   中英

如何將月份名稱轉換為月份編號

[英]How to convert month name to month number

我想將月份名稱轉換為月份編號。 通過使用此代碼,它僅顯示12月的結果,其他月份則無效。 但是如果我改變一年,那是工作。 例如,我選擇11月和2015年,結果是12月和2015年。如果我選​​擇11月和2014年,結果是12月和2014年。

數據庫中的值為2015-09-28。 我認為如何將月份名稱轉換為月份編號存在錯誤。 有人可以幫我修復我的代碼。

這是我的代碼:

視圖

  <?php echo form_open("announcement/announcement_result");?>
  <?php echo form_dropdown('m', $m, set_value('m'), 'id="m"'); ?>
  <?php echo form_dropdown('q', $q, set_value('q'), 'id="q"'); ?>
  <?php echo form_submit('search', 'SEARCH', 'class="button expand"'); ?>
  <?php echo form_close(); ?>

控制器

function announcement_list()
{

  $data['q'] = array(
    '' => ' Select Year',);   

  for ($i = 0; $i < 10; $i++)
    {
    $date = date('Y') - $i;
    $data['q'][$date] = $date; 
    }

  $m = '';
      $data['m'] = $m;
  $data['m'] = array(
          '' => 'Select Month',
      );
      for ($m = 1; $m <= 12; $m++) {
          $month = date("F", mktime(0, 0, 0, $m));
          $data['m'][$month] = $month;      
    }


    if ($m='December') 
    {
      $m='12';
    }
    else if($m='November') 
    {
      $m='11';
    }
    else if ($m='October') 
    {
      $m='10';
    }
    else if ($m='September') 
    {
      $m='9';
    }
    else if ($m='August') 
    {
      $m='8';
    }
    else if ($m='July') 
    {
      $m='7';
    }
    else if ($m='June') 
    {
      $m='6';
    }
    else if ($m='May') 
    {
      $m='5';
    }
    else if ($m='April') 
    {
      $m='4';
    }
    else if ($m='March') 
    {
      $m='3';
    }                                                           
    else if ($m='February') 
    {
      $m='2';
    }
    else if ($m='January')
    {
      $m='1';
    }
    $data['results'] = $this->news_model->get_announcement_list($config['per_page'], $page);
    }

模型

    function get_results($m, $q, $limit=6, $offset=0)
{
    $sql = "SELECT *
        FROM ArkibBerita
        WHERE code='PENGUMUMAN' AND Enable = 'Y' AND Lang ='EN' AND YEAR(BeritaDate)='{$q}' AND MONTH(BeritaDate)='{$m}'
        ORDER BY position ASC
        OFFSET {$offset} ROWS
        FETCH NEXT {$limit} ROWS ONlY";

        $query = $this->db->query($sql);
        return $query->result();

}

關於什么:

echo date('m', strtotime('january'));

輸出:

01

如果您不希望前導零使用n或參閱手冊以了解其他用法。 http://php.net/manual/zh/function.date.php

在代碼中,您沒有在比較日期,而是在設置日期。

if ($m='December') 

應該

if ($m=='December') 

一個等於一組。 兩個等於比較。 三個等於比較並且需要相同的變量類型。 http://php.net/manual/zh/language.operators.comparison.php

因此,在每次迭代中,您的$m將為12因為$m始終設置為字符串,這是它遇到的第一個條件。 如果您取消訂單,則將其設置為1

您還應該考慮對SQL查詢使用准備好的語句。 http://php.net/manual/zh/security.database.sql-injection.php

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM