我如何在mysql表中存储营业时间

问题描述 投票:3回答:1

我正在一个涉及当地餐馆的网站上工作,我需要做的一件事是将餐厅营业时间存储在mysql中。

从HTML到PHP的数据看起来像这样。

// Eg: from Monday to Saturday 8am to 10pm
$_POST['from'], $_POST['to'], $_POST['opening_time'], $_POST['closing_time']

我的sql表结构是这样的。

CREATE TABLE business_hours (
  id integer NOT NULL PRIMARY KEY,
  restaurant_id integer NOT NULL,
  day integer NOT NULL,
  open_time time,
  close_time time
)

我的问题是我从上面的用户那里得到两天的开放和关闭时间。所以现在我需要在这两天之间的所有记录中插入business_hours表。

例如:MondayFriday(如果一周的开始和结束时间)

然后我需要将这些营业时间存储在我的表格中

Monday,9am,11pm
Tuesday,9am,11pm
Wednesday,9am,11pm
Thursday,9am,11pm
Friday,9am,11pm

谁能告诉我怎么办?

任何想法将不胜感激。

谢谢。

php mysql
1个回答
0
投票

经过大量的研究,试验和错误,这最终对我有用。数据全部基于用于动态结构化标记的餐馆的条目。

用于创建表的SQL:

CREATE TABLE tbl_businesshrs (
`id` int(11) NOT NULL,
`tbl_index_id` int(11) NOT NULL,
`DoW` varchar(128) NOT NULL,
`status` enum('Open','Closed') NOT NULL COMMENT '0 is Cosed',
`start_time` varchar(128) NOT NULL,
`end_time` varchar(128) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

tbl_index_id是餐厅餐桌中餐厅的ID,它是INDEX,DoW是星期几。

我还包括AJAX函数,用于在更改小时数时更新营业时间表。然后在餐厅设置php页面我包括一周的每一天的记录源查询,用存储在数据库中的值更新选择字段。

查询:

<?php 
$colname_rs_mondayshrs = "-1"; 
if (isset($_GET['restaurantid'])) { 
  $colname_rs_mondayshrs = $_GET['restaurantid']; 
} 
mysqli_select_db( $restaurant, $database_restaurant); 
$query_rs_mondayshrs = sprintf("SELECT * FROM tbl_businesshrs WHERE tbl_index_id = %s 
AND DoW='Monday'", GetSQLValueString($colname_rs_mondayshrs, "int")); 
$rs_mondayshrs = mysqli_query( $restaurant, $query_rs_mondayshrs) or 
die(mysqli_error($GLOBALS["___mysqli_ston"])); 
$row_rs_mondayshrs = mysqli_fetch_assoc($rs_mondayshrs); 
$totalRows_rs_mondayshrs = mysqli_num_rows($rs_mondayshrs);    

?> 

一周中的每一天都是如此。然后,宏伟的PHP stcrcmp函数会比较数据库中的打开和关闭条目,并使用相关条目填充选择选项:

<select id="mondaystatus" onChange="update_mondaystatus()">
                      <option selected value="" <?php if (!(strcmp("", 
$row_rs_mondayshrs['status']))) {echo "selected=\"selected\"";} ?>>Open or Closed? 
</option>
                      <option value="Open" <?php if (!(strcmp("Open", 
$row_rs_mondayshrs['status']))) {echo "selected=\"selected\"";} ?>>Open</option>
                      <option value="Closed" <?php if (!(strcmp("Closed", 
$row_rs_mondayshrs['status']))) {echo "selected=\"selected\"";} ?>>Closed</option>
                    </select>

结果:

enter image description here

以及db中的结果:

enter image description here

我可以添加AJAX功能,如果有人感兴趣,或者它可以帮助节省一些宝贵的时间。

© www.soinside.com 2019 - 2024. All rights reserved.