SW/assets/php/common/session_dao.php

115 lines
4.5 KiB
PHP
Raw Normal View History

2021-04-28 21:46:10 +02:00
<?php
2021-05-05 21:11:27 +02:00
include_once('session.php');
2021-04-28 21:46:10 +02:00
class SessionDAO extends DAO {
//Constructor:
function __construct($bd_name){
parent::__construct($bd_name);
}
//Methods:
public function createSession($id, $idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format){
$format = $this->mysqli->real_escape_string($format);
$date = date('Y-m-d', strtotime( $date ) );
$startTime = date('H:i:s', strtotime( $startTime ) );
2021-05-07 13:48:50 +02:00
$sql = sprintf( "INSERT INTO `session` (`id`, `idfilm`, `idhall`, `idcinema`, `date`, `start_time`, `seat_price`, `format`, `seats_full`)
VALUES ('%d', '%d', '%d', '%d', '%s', '%s', '%d', '%s', '%d')",
$id, $idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format, "0");
2021-04-28 21:46:10 +02:00
2021-05-09 20:31:54 +02:00
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database');
2021-04-28 21:46:10 +02:00
return $sql;
}
//Returns a query to get the session's data.
public function sessionData($id){
$sql = sprintf( "SELECT * FROM `session` WHERE id = '%d'", $id );
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database en sessionData con la id '. $id);
2021-05-07 13:48:50 +02:00
$resul = mysqli_fetch_array($resul);
2021-04-28 21:46:10 +02:00
return $resul;
}
2021-05-07 13:48:50 +02:00
public function filmTittle($idfilm){
$sql = sprintf("SELECT * FROM film JOIN session ON film.id = session.idfilm WHERE session.idfilm = '%d' ", $idfilm );
2021-05-09 20:31:54 +02:00
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database en sessionData con la id '. $idfilm);
2021-05-07 13:48:50 +02:00
$resul = mysqli_fetch_array($resul);
return $resul;
}
//Returns a session
2021-04-28 21:46:10 +02:00
public function searchSession($cinema, $hall, $startTime, $date){
$date = date('Y-m-d', strtotime( $date ) );
$startTime = date('H:i:s', strtotime( $startTime ) );
2021-05-07 13:48:50 +02:00
$sql = sprintf( "SELECT * FROM session WHERE
2021-04-28 21:46:10 +02:00
idcinema = '%s' AND idhall = '%s' AND date = '%s' AND start_time = '%s'",
$cinema, $hall, $date, $startTime);
2021-05-09 20:31:54 +02:00
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database');
2021-04-28 21:46:10 +02:00
$session = mysqli_fetch_array($resul);
mysqli_free_result($resul);
2021-05-07 13:48:50 +02:00
return $session;
2021-04-28 21:46:10 +02:00
}
//Returns a query to get all the session's data.
2021-05-05 21:11:27 +02:00
public function getAllSessions($hall, $cinema, $date){
2021-04-28 21:46:10 +02:00
$date = date('Y-m-d', strtotime( $date ) );
$sql = sprintf( "SELECT * FROM session WHERE
2021-05-05 21:11:27 +02:00
idcinema = '%s' AND idhall = '%s' AND date = '%s' ORDER BY start_time ASC;",
2021-04-28 21:46:10 +02:00
$cinema, $hall, $date);
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database');
$sessions = null;
while($fila=mysqli_fetch_array($resul)){
2021-05-07 13:48:50 +02:00
$sessions[] = $this->loadSession($fila["id"], $fila["idfilm"], $fila["idhall"], $fila["idcinema"], $fila["date"], $fila["start_time"], $fila["seat_price"], $fila["format"], $fila["seats_full"]);
2021-04-28 21:46:10 +02:00
}
mysqli_free_result($resul);
return $sessions;
}
2021-05-06 18:11:12 +02:00
public function editSession($idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format, $origin){
2021-04-28 21:46:10 +02:00
$format = $this->mysqli->real_escape_string($format);
$date = date('Y-m-d', strtotime( $date ) );
$startTime = date('H:i:s', strtotime( $startTime ) );
$sql = sprintf( "UPDATE `session`
SET `idfilm` = '%d' , `idhall` = '%d', `idcinema` = '%d', `date` = '%s',
`start_time` = '%s', `seat_price` = '%d', `format` = '%s'
WHERE
idcinema = '%s' AND idhall = '%s' AND date = '%s' AND start_time = '%s'",
2021-05-06 18:11:12 +02:00
$idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format, $origin["cinema"],$origin["hall"],$origin["date"],$origin["start"]);
2021-04-28 21:46:10 +02:00
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database');
return $resul;
}
public function deleteSession($hall, $cinema, $date, $startTime){
$sql = sprintf( "DELETE FROM `session` WHERE
idcinema = '%s' AND idhall = '%s' AND date = '%s' AND start_time = '%s'",
$cinema, $hall, $date, $startTime);
$resul = mysqli_query($this->mysqli, $sql) or die ('Error into query database');
return $resul;
}
//Create a new Session Data Transfer Object.
2021-05-07 13:48:50 +02:00
public function loadSession( $id, $idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format, $seats_full){
return new Session( $id, $idfilm, $idhall, $idcinema, $date, $startTime, $seatPrice, $format, $seats_full);
2021-04-28 21:46:10 +02:00
}
}
?>