-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmenu.class.php
67 lines (56 loc) · 1.44 KB
/
menu.class.php
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
declare(strict_types = 1);
class Menu {
public int $id;
public string $name;
public int $restaurant;
public function __construct(int $id, string $name, int $restaurant)
{
$this->id = $id;
$this->name = $name;
$this->restaurant = $restaurant;
}
static function getRestaurantMenus(PDO $db, int $id) : array {
$stmt = $db->prepare('
SELECT MenuId, MenuType
FROM Menu natural join RestaurantMenu
WHERE RestaurantId = ?
GROUP BY MenuId
');
$stmt->execute(array($id));
$Menus = array();
while ($Menu = $stmt->fetch()) {
$Menus[] = new Menu(
intval($Menu['MenuId']),
$Menu['MenuType'],
$id
);
}
return $Menus;
}
static function getMenu(PDO $db, int $id) : Menu {
$stmt = $db->prepare('
SELECT MenuId, MenuType, RestaurantId
FROM Menu natural join RestaurantMenu
WHERE MenuId = ?
GROUP BY MenuId
');
$stmt->execute(array($id));
$Menu = $stmt->fetch();
return new Menu(
intval($Menu['MenuId']),
$Menu['MenuType'],
intval($Menu['RestaurantId'])
);
}
static function countMenu(PDO $db){
$stmt = $db->prepare('
SELECT MAX(MenuId)
FROM Menu
');
$stmt->execute(array());
$count = $stmt->fetch();
return $count['MAX(MenuId)'];
}
}
?>