Diskuze: jak volat data z DB Objektově
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 4 zpráv z 4.
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Omlouvám se za prohozené tagy správně je to zde.
<p class="right-cite"><cite><strong>— <?= $row['citat_autor']; ?></strong></cite></p>
Také se chci zeptat zda správně ukončuji spojení s DB
<?php
class Citat extends Database {
public function getCitat() {
// sloupce v DB jsou ID_citat, citat_autor, citat
$sql = "SELECT citat, citat_autor FROM citaty ORDER BY Rand() LIMIT 1";
$stmt = $this->connect()->query($sql);
while($row = $stmt->fetch()) {
echo $row['citat'] . '<br>' . $row['citat_autor']; //funguje načte a zobrazí citát i autora
}
$this->connect = null;
}
}
google = php encode html entities
google = php decode html entities
php.net/htmlentities
htmlentities
htmlspecialchars
htmlspecialchars_decode
html_entity_decode
google = php encode html mathml
https://annevankesteren.nl/…r-references
Návrh bych takovéto řešení.
Database.php
<?php
class Database {
private $servername;
private $username;
private $password;
private $dbname;
private $charset;
private $pdo = null;
private function createPDOConnection() {
$this->servername = "localhost";
$this->username = "root";
$this->password = "";
$this->dbname = "grizzly";
$this->charset = "utf8mb4";
$dsn = "mysql:host=".$this->servername.";dbname=".$this->dbname.";charset=".$this->charset;
$pdo = new PDO($dsn, $this->username, $this->password);
$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$this->pdo = $pdo;
}
protected function execSingleResultQuery($sql)
{
try {
if ($this->pdo === null) {
$this->createPDOConnection(); // pokud by se v běhu kodu volalo více sql tak se bude využívat jedno připojení a nebude se zbytečně otvírat nové.
}
$statement = $this->pdo->prepare($sql);
$statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC);
} catch (PDOException $e) {
echo "Connection failed: " . $e->getMessage(); // echal bych jí vyletět až uplně nehoru ale to záleží no
die();
}
}
}
Citat.php
<?php
class Citat
{
private $citat;
private $autor;
public function __construct($citat, $autor)
{
$this->citat = $citat;
$this->autor = $autor;
}
public function getCitatHtmlDecoded()
{
return html_entity_decode($this->citat);
}
public function getAutor()
{
return $this->autor;
}
}
CitatRepository.php
<?php
class CitatRepository extends Database {
public function getCitat() {
// sloupce v DB jsou ID_citat, citat_autor, citat
$sql = "SELECT citat, citat_autor FROM citaty ORDER BY Rand() LIMIT 1";
$result = $this->execSingleResultQuery($sql);
if ($result === false || $result === []) {
return new Citat('', ''); // chtělo by to vymyslel lepší řešení když nic nejdeme, ale pro ukázku to stačí
}
return new Citat($result['citat'], $result['citat_autor']);
}
}
index.php
<?php
require_once('includes/autoloader.inc.php');
$repository = new CitatRepository();
$citat = $repository->getCitat();
?>
<!DOCTYPE html>
<html lang="cs">
<head>
<title></title>
</head>
<body>
<div class="cite">
<div class="mount-cite">
<h2>Citát dne</h2>
<p>„<?= $citat->getCitatHtmlDecoded() ?>“</p>
<p class="right-cite"><cite><strong>— <?= $citat->getAutor() ?></strong></cite></p>
</div>
</div>
</body>
</html>
Zobrazeno 4 zpráv z 4.