2016-07-07 59 views
0

你好,我想获取所有的数据顺序在月,但我的问题是数据类型的月我的数据库是varchar可以有人给我的想法如何做到这一点?PHP - 按月排序,但数据类型是varchar?

这里是我的SQL enter image description here

这里的结构是查询的输出到事件

enter image description here

,这里是我的事件代码

<div class="col-xs-6 col-md-3"> 
      <div class="title2"> 
          <h2><i class="fa fa-calendar"></i> Upcoming Events</h2> 
      </div> 
     <div class="fix sidebar floatright"> 
      <div class="fix single_sidebar"> 
       <div class="events"> 

        <?php 
        include_once('connection.php'); 
        $sql ="SELECT * FROM events ORDER BY month"; 
        $result = mysqli_query($con, $sql); 

        while($row = mysqli_fetch_array($result)){ 

           $month = $row['month']; 
           $day = $row['day']; 
           $year = $row['year']; 
           $etitle = $row['event_title']; 
           $stime = $row['start_time']; 
           $etime = $row['end_time']; 
           $evenue = $row['event_venue']; 
         ?> 
         <div class="fix single_events"> 
            <div class="date"> 
             <span class="month"><?php echo $month; ?></span> 
              <h1 class="day"><?php echo $day; ?></h1> 
            </div> 
            <h2><?php echo $etitle; ?></h2> 
            <p><?php echo $stime; ?> - <?php echo $etime; ?></p> 
            <p><?php echo $evenue; ?></p> 
           </div> 
           <hr> 
            <?php 
         } 
        ?> 


       </div> 
      </div> 
     </div> 
     </div> 
+1

在'varchar' _永远_存储日期,商店为'datetime'相反,这是你的问题的最简单的方法。如果您向我们显示查询的实际输出,则可能有人会给您一个解决方法。 –

+1

如果您更改了列类型,它将在未来减少您的麻烦。解决方法是使用MySQL的['FIELD()'](http://dev.mysql.com/doc/refman/5.7/en/string-functions.html#function_field) - >'SELECT * FROM events ORDER按字段(月,'1月','2月',...)' – Sean

回答

2

问题是month是一个字符串,而不是数字值。

不知道值,很难建议一个特定的解决方案。但这里是一个想法:

order by field(month, 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec')