我正在一个涉及当地餐馆的网站上工作,我需要做的一件事是将餐厅营业时间存储在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
表中插入这两天之间的所有记录。
例如:Monday
,Friday
(如果一周的开始和结束时间)
然后我需要将这些营业时间存储在我的表格中
Monday,9am,11pm
Tuesday,9am,11pm
Wednesday,9am,11pm
Thursday,9am,11pm
Friday,9am,11pm
有谁能告诉我怎么办?
任何想法都会非常感激。
谢谢。
答案 0 :(得分: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>
结果:
和db中的结果:
我可以添加AJAX功能,如果有人感兴趣,或者它可以帮助节省一些宝贵的时间。