Rozwiązanie - Egzamin Praktyczny EE.09

Arkusz EE.09-03-22.06-SG - Czerwiec 2022 - Wersja #03

Skrypt: PHP

Baza Danych:

Przykładowe rozwiązanie
Rozwiązanie - Arkusz praktyczny EE.09-03-22.06-SG - Czerwiec 2022 - Wersja #03
Wymagane zdjęcia
Egzamin EE.09-03-22.06-SG - dodatkowe zdjęcia - anna.jpg
anna.jpg
Egzamin EE.09-03-22.06-SG - dodatkowe zdjęcia - ewa.jpg
ewa.jpg
Egzamin EE.09-03-22.06-SG - dodatkowe zdjęcia - janek.jpg
janek.jpg
Egzamin EE.09-03-22.06-SG - dodatkowe zdjęcia - john.jpg
john.jpg
Egzamin EE.09-03-22.06-SG - dodatkowe zdjęcia - judy.jpg
judy.jpg
Wyniki działań na bazie danych
Egzamin EE.09-03-22.06-SG - Operacje na bazie danych - import.jpeg
import.jpeg
Egzamin EE.09-03-22.06-SG - Operacje na bazie danych - import.jpeg
kw1.png
Egzamin EE.09-03-22.06-SG - Operacje na bazie danych - import.jpeg
kw2.png
Egzamin EE.09-03-22.06-SG - Operacje na bazie danych - import.jpeg
kw3.png
Egzamin EE.09-03-22.06-SG - Operacje na bazie danych - import.jpeg
kw4.png
Plik hurtownia.sql
-- phpMyAdmin SQL Dump
-- version 5.2.0
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Czas generowania: 28 Mar 2023, 19:40
-- Wersja serwera: 10.4.27-MariaDB
-- Wersja PHP: 8.2.0

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
START TRANSACTION;
SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8mb4 */;

--
-- Baza danych: `hurtownia`
--

-- --------------------------------------------------------

--
-- Struktura tabeli dla tabeli `klienci`
--

CREATE TABLE `klienci` (
  `id` int(10) UNSIGNED NOT NULL,
  `Typy_id` int(10) UNSIGNED NOT NULL,
  `imie` text DEFAULT NULL,
  `nazwisko` text DEFAULT NULL,
  `zdjecie` varchar(20) DEFAULT NULL,
  `punkty` int(10) UNSIGNED DEFAULT NULL,
  `adres` varchar(50) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

--
-- Zrzut danych tabeli `klienci`
--

INSERT INTO `klienci` (`id`, `Typy_id`, `imie`, `nazwisko`, `zdjecie`, `punkty`, `adres`) VALUES
(1, 2, 'Anna', 'Kowalska', 'anna.jpg', 2000, NULL),
(2, 2, 'Ewa', 'Nowakowska', 'ewa.jpg', 2045, NULL),
(3, 1, 'Krystyna', 'Nowakowska', 'krycha.jpg', 100, NULL),
(4, 3, 'Jan', 'Nowak', 'janek.jpg', 3305, NULL),
(5, 2, 'John', 'Smith', 'john.jpg', 2005, NULL),
(6, 3, 'Judy', 'Beck', 'judy.jpg', 3055, NULL),
(7, 1, 'Marcin', 'Kowalski', 'marcin.jpg', 1045, NULL),
(8, 1, 'Kris', 'Smith', 'Kris.jpg', 0, NULL),
(9, 1, 'Jacek', 'Jackowski', 'jacek.jpg', 45, NULL);

-- --------------------------------------------------------

--
-- Struktura tabeli dla tabeli `opinie`
--

CREATE TABLE `opinie` (
  `id` int(10) UNSIGNED NOT NULL,
  `Klienci_id` int(10) UNSIGNED NOT NULL,
  `opinia` text DEFAULT NULL,
  `ocena` tinyint(3) UNSIGNED DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

--
-- Zrzut danych tabeli `opinie`
--

INSERT INTO `opinie` (`id`, `Klienci_id`, `opinia`, `ocena`) VALUES
(1, 1, 'Dobra współpraca, zawsze świeże towary i miła obsługa', 6),
(2, 2, 'Polecam hurtownię za profesjonalne podejście do klienta', 6),
(3, 3, 'Wszystkie transakcje przebiegły sprawnie', 5),
(4, 4, 'Polecam hurtownię za profesjonalne podejście do klienta', 5),
(5, 5, 'Wszystkie transakcje przebiegły sprawnie', 5),
(6, 6, 'Truskawki, które zakupiłam były nieświeże, poza tym wszystko ok', 4);

-- --------------------------------------------------------

--
-- Struktura tabeli dla tabeli `typy`
--

CREATE TABLE `typy` (
  `id` int(10) UNSIGNED NOT NULL,
  `nazwa` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

--
-- Zrzut danych tabeli `typy`
--

INSERT INTO `typy` (`id`, `nazwa`) VALUES
(1, 'zwykły'),
(2, 'złoty'),
(3, 'platynowy');

--
-- Indeksy dla zrzutów tabel
--

--
-- Indeksy dla tabeli `klienci`
--
ALTER TABLE `klienci`
  ADD PRIMARY KEY (`id`);

--
-- Indeksy dla tabeli `opinie`
--
ALTER TABLE `opinie`
  ADD PRIMARY KEY (`id`);

--
-- Indeksy dla tabeli `typy`
--
ALTER TABLE `typy`
  ADD PRIMARY KEY (`id`);

--
-- AUTO_INCREMENT dla zrzuconych tabel
--

--
-- AUTO_INCREMENT dla tabeli `klienci`
--
ALTER TABLE `klienci`
  MODIFY `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=10;

--
-- AUTO_INCREMENT dla tabeli `opinie`
--
ALTER TABLE `opinie`
  MODIFY `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=7;

--
-- AUTO_INCREMENT dla tabeli `typy`
--
ALTER TABLE `typy`
  MODIFY `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=4;
COMMIT;

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
Plik kwerendy.txt
Zapytanie 1: SELECT imie, nazwisko, punkty FROM klienci ORDER BY punkty DESC LIMIT 3;
Zapytanie 2: SELECT typy.nazwa, COUNT(klienci.id) FROM typy, klienci WHERE typy.id = klienci.typy_id GROUP BY typy.nazwa;
Zapytanie 3: SELECT klienci.zdjecie, klienci.imie, opinie.opinia FROM klienci, opinie, typy WHERE klienci.id = opinie.klienci_id AND typy.id = klienci.typy_id AND typy.id IN (2,3);
Zapytanie 4: ALTER TABLE klienci ADD COLUMN adres VARCHAR(50)
Plik opinie.php
<?php
    $conn = new mysqli("localhost","root","","hurtownia");
?>

<!DOCTYPE html>
<html lang="pl">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Opinie klientów</title>
        <link rel="stylesheet" href="styl3.css">
    </head>
    <body>
        <header>
            <h1>Hurtownia spożywcza</h1>
        </header>

        <main>
            <h2>Opinie naszych klientów</h2>
            <?php
                // Skrypt #1
                $sql = "SELECT klienci.zdjecie, klienci.imie, opinie.opinia FROM klienci, opinie, typy WHERE klienci.id = opinie.klienci_id AND typy.id = klienci.typy_id AND typy.id IN (2,3);";
                $result = $conn->query($sql);
                
                while($row = $result -> fetch_array()) {
                    echo "<div class='opinia'>";
                        echo "<img src='$row[0]' alt='klient'>";
                        echo "<div class='cytat'>$row[2]</div>";
                        echo "<h4>$row[1]</h4>";
                    echo "</div>";
                }
            ?>
        </main>

        <div id="stopka1">
            <h3>Współpracują z nami</h3>
            <a href="http://skle.pl/">Sklep 1</a>
        </div>

        <div id="stopka2">
            <h3>Nasi top klienci</h3>
            <ol>
                <?php
                    // Skrypt #2
                    $sql = "SELECT imie, nazwisko, punkty FROM klienci ORDER BY punkty DESC LIMIT 3;";
                    $result = $conn->query($sql);

                    while($row = $result -> fetch_array()) {
                        echo "<li>$row[0] $row[1], $row[2]</li>";
                    }
                ?>
            </ol>
        </div>

        <div id="stopka3">
            <h3>Skontaktuj się</h3>
            <p>telefon: 111222333</p>
        </div>

        <div id="stopka4">
            <h3>Autor: <a href="https://ee-informatyk.pl/" target="_blank" style="color: unset;text-decoration: none;">EE-Informatyk.pl</a></h3>
        </div>
    </body>
</html>

<?php
    $conn -> close();
?>
Plik styl3.css
* {
    font-family: 'Tahoma','sans-serif';
}

header {
    background: tomato;
    color: white;
    padding: 10px;
}

main {
    background: seashell;
    height: 500px;
    overflow: scroll;
}

#stopka1,#stopka2,#stopka3,#stopka4 {
    background: tomato;
    color: white;
    width: 25%;
    height: 160px;
    float: left;
}

.opinia {
    background: white;
    color: dimgray;
    width: 60%;
    height: 220px;
    margin: 40px auto;
    box-shadow: 0px 0px 10px 5px dimgrey;
}

img {
    margin: 10px;
    border-radius: 10px;
    float: left;
}

.cytat {
    padding: 10px;
    font-size: 150%;
    font-style: italic;
}

h1,h2 {
    text-align: center;
}

h4 {
    text-align: right;
    margin-right: 40px;
    font-size: 150%;
    font-style: italic;
    float: right;
}

a {
    color: white;
}

Strona używa plików cookies

Serwis wykorzystuje ciasteczka głównie w celu prowadzenia systemu formularzy oraz zbierania danych dotyczących ruchu na stronie.

Więcej informacji znajdziesz w Polityce Prywatności

Akceptuję