簡體   English   中英

如何使用PHP在mysql中插入不規則日歷事件

[英]How to insert an irregular calendar events in mysql using PHP

我正在嘗試輸入在相同時間間隔(每周,每月兩次,每季度,每年)中發生的事件。 我要顯示的腳本是每月的腳本。(如果我能做到的話,我可以對其他時間間隔進行改編)。

輸入了事件以及發生事件的正確星期數。。但是發生了以下問題:

---如何確定少於31天的月份沒有為他們輸入事件? -----如果在每個第1和第3個星期五(或每個星期五)或該月的最后一個星期四發生事件。 我如何調整下面的腳本來做到這一點。

謝謝。

當我插入時,我從mysql得到的樣本...

+----+------+------+------------------+-----------+------------+----------+
| day| month| year | eventname        | eventtime | eventplace | eventweek|
+----+------+------+------------------+-----------+------------+-----------
|  1 |    2 | 2011 | Social Gathering | 12PM      | Room       |   05     |
|  8 |    2 | 2011 | Social Gathering | 12PM      | Room       |   06     |
|  15|    2 | 2011 | Social Gathering | 12PM      | Room       |   07     |
|  22|    2 | 2011 | Social Gathering | 12PM      | Room       |   08     |
|  29|    2 | 2011 | Social Gathering | 12PM      | Room       |   09     |
+----+------+------+------------------+-----------+------------+----------+

PHP代碼

<?php 
    if(isset($_POST['myform'])){

             $day   =   array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23','24','25','26','27','28','29','30','31');
             $month =   array('1','2','3','4','5','6','7','8','9','10','11','12');              
             $year  =   array('2011', '2012','2013', '2014', '2015', '2016');   

   $startday   =  mysql_real_escape_string($_POST['day']);
   $eventplace =  mysql_real_escape_string($_POST['eventplace']);
   $eventname  =  mysql_real_escape_string($_POST['eventname']);
   $eventtime  =  mysql_real_escape_string($_POST['eventtime']);

            for($i=0; $i<count($year); $i++){
                for($j=0; $j<count($month); $j++){
                    for($k=$startday; $k<count($day); $k = $k + 7){
                        $date = mktime(0,0,0,$month[$j],$k,$year[$i]); 
                            $week = date('W', $date) ;
      $query = mysql_query(" INSERT INTO caldemo(day, month, year, eventname, eventtime, eventplace, eventweek)
                             VALUES ('".intval($k)."', '".intval($month[$j])."', '".intval($year[$i])."', '".$eventname."', '".$eventtime."', '".$eventplace."', '".intval($week)."' )")or die(mysql_error()) ;
                  }
                }
             } 
          }
?>

簡單的php解決方案:

function setDatePeriod($months=1, $date='')
{
    if(!$date) $date = date('Y-m-d');
    $d = new DateTime( $date );
    $d->modify( "+{$months} months" );
    return $d->format('Y-m-d');
}
echo setDatePeriod(3);

暫無
暫無

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

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