0
你好,我想获取所有的数据顺序在月,但我的问题是数据类型的月我的数据库是varchar可以有人给我的想法如何做到这一点?PHP - 按月排序,但数据类型是varchar?
这里的结构是查询的输出到事件
,这里是我的事件代码
<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>
在'varchar' _永远_存储日期,商店为'datetime'相反,这是你的问题的最简单的方法。如果您向我们显示查询的实际输出,则可能有人会给您一个解决方法。 –
如果您更改了列类型,它将在未来减少您的麻烦。解决方法是使用MySQL的['FIELD()'](http://dev.mysql.com/doc/refman/5.7/en/string-functions.html#function_field) - >'SELECT * FROM events ORDER按字段(月,'1月','2月',...)' – Sean