Rozwiązanie - Egzamin Praktyczny E.14

Arkusz E.14-05-19.01 - Styczeń 2019 - Wersja #05

Skrypt: PHP

Baza Danych:

Przykładowe rozwiązanie
Rozwiązanie - Arkusz praktyczny E.14-05-19.01 - Styczeń 2019 - Wersja #05
Wymagane zdjęcia
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - boczniak.jpg
boczniak.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - borowik.jpg
borowik.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - borowik-miniatura.jpg
borowik-miniatura.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - kania.jpg
kania.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - kurka.jpg
kurka.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - pieczarka.jpg
pieczarka.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - podgrzybek.jpg
podgrzybek.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - szatan.jpg
szatan.jpg
Egzamin E.14-05-19.01 - dodatkowe zdjęcia - trufla.jpg
trufla.jpg
Wyniki działań na bazie danych
Egzamin E.14-05-19.01 - Operacje na bazie danych - import.png
import.png
Egzamin E.14-05-19.01 - Operacje na bazie danych - import.png
kw1.png
Egzamin E.14-05-19.01 - Operacje na bazie danych - import.png
kw2.png
Egzamin E.14-05-19.01 - Operacje na bazie danych - import.png
kw3.png
Egzamin E.14-05-19.01 - Operacje na bazie danych - import.png
kw4.png
Plik dane2.sql
-- phpMyAdmin SQL Dump
-- version 5.2.0
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Czas generowania: 10 Mar 2023, 10:59
-- 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: `dane2`
--

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

--
-- Struktura tabeli dla tabeli `grzyby`
--

CREATE TABLE `grzyby` (
  `id` int(10) UNSIGNED NOT NULL,
  `rodzina_id` int(10) UNSIGNED NOT NULL,
  `potrawy_id` int(10) UNSIGNED NOT NULL,
  `nazwa` text DEFAULT NULL,
  `potoczna` text DEFAULT NULL,
  `jadalny` tinyint(1) DEFAULT NULL,
  `miesiac_zbierania` int(11) DEFAULT NULL,
  `nazwa_pliku` text DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;

--
-- Zrzut danych tabeli `grzyby`
--

INSERT INTO `grzyby` (`id`, `rodzina_id`, `potrawy_id`, `nazwa`, `potoczna`, `jadalny`, `miesiac_zbierania`, `nazwa_pliku`) VALUES
(1, 1, 2, 'pieczarka dwuzarodnikowa', 'pieczarka', 1, 0, 'pieczarka.jpg'),
(2, 1, 2, 'czubajka kania', 'kania', 1, 9, 'kania.jpg'),
(3, 2, 4, 'borowik szlachetny', 'prawdziwek', 1, 10, 'borowik.jpg'),
(4, 2, 4, 'xerocomus', 'podgrzybek', 1, 10, 'podgrzybek.jpg'),
(5, 2, 5, 'goryczak zolciowy', 'szatan', 0, -1, 'szatan.jpg'),
(6, 3, 1, 'pieprznik jadalny', 'kurka', 1, 9, 'kurka.jpg'),
(7, 5, 1, 'pleurotus', 'boczniak', 1, 0, 'boczniak.jpg'),
(8, 4, 3, 'trufla letnia', 'trufla', 1, 8, 'trufla.jpg');

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

--
-- Struktura tabeli dla tabeli `potrawy`
--

CREATE TABLE `potrawy` (
  `id` int(10) UNSIGNED NOT NULL,
  `nazwa` text DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;

--
-- Zrzut danych tabeli `potrawy`
--

INSERT INTO `potrawy` (`id`, `nazwa`) VALUES
(1, 'sos'),
(2, 'duszone'),
(3, 'spagetti'),
(4, 'zupa'),
(5, 'niejadalne');

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

--
-- Struktura tabeli dla tabeli `rodzina`
--

CREATE TABLE `rodzina` (
  `id` int(10) UNSIGNED NOT NULL,
  `nazwa` text DEFAULT NULL,
  `opis` text DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;

--
-- Zrzut danych tabeli `rodzina`
--

INSERT INTO `rodzina` (`id`, `nazwa`, `opis`) VALUES
(1, 'pieczarkowate', NULL),
(2, 'borowikowate', NULL),
(3, 'pieprznikowate', NULL),
(4, 'truflowate', NULL),
(5, 'boczniakowate', NULL);

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

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

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

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

--
-- AUTO_INCREMENT dla zrzuconych tabel
--

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

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

--
-- AUTO_INCREMENT dla tabeli `rodzina`
--
ALTER TABLE `rodzina`
  MODIFY `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=6;
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 nazwa, potoczna FROM grzyby WHERE jadalny = 1;
Zapytanie 2: SELECT grzyby.nazwa, grzyby.potoczna, rodzina.nazwa FROM grzyby, rodzina, potrawy WHERE grzyby.rodzina_id = rodzina.id AND grzyby.potrawy_id = potrawy.id AND potrawy.nazwa = 'sos';
Zapytanie 3: SELECT nazwa_pliku, potoczna FROM grzyby;
Zapytanie 4: ALTER TABLE rodzina ADD COLUMN (opis TEXT);
Plik grzyby.php
<?php
    $conn = new mysqli("localhost","root","","dane2");
?>

<!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>Grzybobranie</title>
        <link rel="stylesheet" href="styl5.css">
    </head>
    <body>
        <div id="logo">
            <a href="borowik.jpg"><img src="borowik-miniatura.jpg" alt="Grzybobranie"></a>
        </div>

        <div id="tytul">
            <h1>Idziemy na grzyby!</h1>
        </div>

        <div id="lewy">
            <?php
                // Skrypt #1
                $sql = "SELECT nazwa_pliku, potoczna FROM grzyby;";
                $result = $conn->query($sql);
                
                while($row = $result -> fetch_array()) {
                    echo "<img src='".$row["nazwa_pliku"]."' alt='".$row["potoczna"]."' title='".$row["potoczna"]."'>";
                }
            ?>
        </div>

        <div id="prawy">
            <h2>Grzyby jadalne</h2>
            <?php
                // Skrypt #2
                $sql = "SELECT nazwa, potoczna FROM grzyby WHERE jadalny = 1;";
                $result = $conn->query($sql);
                
                while($row = $result -> fetch_array()) {
                    echo "<p>".$row["nazwa"]." (".$row["potoczna"].")</p>";
                }
            ?>
            <h2>Polecamy do sosów</h2>
            <?php
                // Skrypt #3
                $sql = "SELECT grzyby.nazwa, grzyby.potoczna, rodzina.nazwa FROM grzyby, rodzina, potrawy WHERE grzyby.rodzina_id = rodzina.id AND grzyby.potrawy_id = potrawy.id AND potrawy.nazwa = 'sos';";
                $result = $conn->query($sql);
                
                echo "<ol>";
                while($row = $result -> fetch_array()) {
                    echo "<li>".$row[0]." (".$row[1].") rodzina: ".$row[2]."</li>";
                }
                echo "</ol>";
            ?>
        </div>

        <footer>
            <p>Autor: <a href="https://ee-informatyk.pl/" target="_blank" style="color: orange; text-decoration: none;">EE-Informatyk.pl</a></p>
        </footer>
    </body>
</html>

<?php
    $conn -> close();
?>
Plik styl5.css
body {
    font-family: Verdana;
}

#logo {
    background: sienna;
    height: 100px;
    width: 20%;
    float: left;
}

#tytul {
    background: sienna;
    color: orange;
    height: 100px;
    width: 80%;
    float: left;
}

#lewy {
    clear: both;
    background: burlywood;
    height: 700px;
    width: 70%;
    float: left;
}

#prawy {
    background: burlywood;
    height: 700px;
    width: 30%;
    float: left;
}

footer {
    background: sienna;
    color: orange;
    text-align: center;
}

img {
    padding: 7px;
    margin: 5px;
    border: 1px solid rosybrown;
}

img:hover {
    border: 1px solid maroon;
}

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ę