Rozwiązanie - Egzamin Praktyczny E.14

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

Skrypt: PHP

Baza Danych:

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

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

--
-- Struktura tabeli dla tabeli `gromady`
--

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

--
-- Zrzut danych tabeli `gromady`
--

INSERT INTO `gromady` (`id`, `nazwa`, `opis`) VALUES
(1, 'ryby', ''),
(2, 'plazy', ''),
(3, 'gady', ''),
(4, 'ptaki', ''),
(5, 'ssaki', '');

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

--
-- Struktura tabeli dla tabeli `odzywianie`
--

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

--
-- Zrzut danych tabeli `odzywianie`
--

INSERT INTO `odzywianie` (`id`, `rodzaj`, `informacja`) VALUES
(1, 'drapieznik', ''),
(2, 'roslinozerny', ''),
(3, 'padlinozerny', ''),
(4, 'wszystkozerny', '');

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

--
-- Struktura tabeli dla tabeli `zwierzeta`
--

CREATE TABLE `zwierzeta` (
  `id` int(10) UNSIGNED NOT NULL,
  `Gromady_id` int(10) UNSIGNED NOT NULL,
  `Odzywianie_id` int(10) UNSIGNED NOT NULL,
  `gatunek` text DEFAULT NULL,
  `wystepowanie` text DEFAULT NULL,
  `czy_zagrozony` tinyint(1) DEFAULT NULL,
  `obraz` text NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;

--
-- Zrzut danych tabeli `zwierzeta`
--

INSERT INTO `zwierzeta` (`id`, `Gromady_id`, `Odzywianie_id`, `gatunek`, `wystepowanie`, `czy_zagrozony`, `obraz`) VALUES
(1, 1, 1, 'Sum pospolity', 'Eurazja', 0, 'sum.jpg'),
(2, 1, 1, 'Jesiotr zachodni', 'Europa', 1, 'jesiotr.jpg'),
(3, 4, 4, 'Wrona siwa', 'Europa', 0, 'wrona.jpg'),
(4, 4, 1, 'Puszczyk zwyczajny', 'Eurazja', 0, 'puszczyk.jpg'),
(5, 4, 4, 'Sroka zwyczajna', 'Eurazja', 0, 'sroka.jpg'),
(6, 5, 1, 'Wilk szary', 'Europa, Ameryka', 0, 'wilk.jpg'),
(7, 5, 3, 'Hiena brunatna', 'Afryka', 0, 'hiena.jpg'),
(8, 5, 2, 'Sarna europejska', 'Europa', 0, 'sarna.jpg'),
(9, 5, 1, 'Dingo australijski', 'Australia', 1, 'dingo.jpg');

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

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

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

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

--
-- AUTO_INCREMENT dla zrzuconych tabel
--

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

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

--
-- AUTO_INCREMENT dla tabeli `zwierzeta`
--
ALTER TABLE `zwierzeta`
  MODIFY `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=10;
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 zwierzeta.id, zwierzeta.gatunek, zwierzeta.wystepowanie FROM zwierzeta, odzywianie WHERE zwierzeta.Odzywianie_id = odzywianie.id AND odzywianie.rodzaj = 'wszystkozerny';
Zapytanie 2: SELECT zwierzeta.gatunek, odzywianie.rodzaj FROM zwierzeta, odzywianie WHERE zwierzeta.Odzywianie_id = odzywianie.id;
Zapytanie 3: SELECT COUNT(*) FROM zwierzeta, odzywianie WHERE zwierzeta.Odzywianie_id = odzywianie.id AND odzywianie.rodzaj = 'drapieznik';
Zapytanie 4: CREATE USER 'JanKowalski' IDENTIFIED BY 'J4nKow';
Plik index.php
<?php
    $conn = new mysqli("localhost","root","","baza");
?>

<!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>Odżywianie zwierząt</title>
        <link rel="stylesheet" href="styl4.css">
    </head>
    <body>
        <header>
            <h2>DRAPIEŻNIKI I INNE</h2>
        </header>

        <div id="formularz">
            <h3>Wybierz styl życia:</h3>
            <form action="index.php" method="post">
                <select name="styl" id="styl">
                    <option value="drapieznik">Drapieżniki</option>
                    <option value="roslinozerny">Roślinożerne</option>
                    <option value="padlinozerny">Padlinożerne</option>
                    <option value="wszystkozerny">Wszystkożerne</option>
                </select>
                <button type="submit">Zobacz</button>
            </form>
        </div>

        <div id="lewy">
            <h3>Lista zwierząt</h3>
            <?php
                // Skrypt #1
                $sql = "SELECT zwierzeta.gatunek, odzywianie.rodzaj FROM zwierzeta, odzywianie WHERE zwierzeta.Odzywianie_id = odzywianie.id";
                $result = $conn->query($sql);

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

        <div id="srodkowy">
            <?php
                // Skrypt #2
                if(isset($_POST["styl"])) {
                    $styl = $_POST["styl"];

                    if($styl == "drapieznik") {
                        echo "<h3>Drapieżniki</h3>";
                    }
                    else if($styl == "roslinozerny") {
                        echo "<h3>Roślinożerne</h3>";
                    }
                    else if($styl == "padlinozerny") {
                        echo "<h3>Padlinożerne</h3>";
                    }
                    else if($styl == "wszystkozerny") {
                        echo "<h3>Wszystkożerne</h3>";
                    }

                    $sql2 = "SELECT zwierzeta.id, zwierzeta.gatunek, zwierzeta.wystepowanie FROM zwierzeta, odzywianie WHERE zwierzeta.Odzywianie_id = odzywianie.id AND odzywianie.rodzaj = '$styl';";
                    $result2 = $conn->query($sql2);
    
                    while($row2 = $result2 -> fetch_array()) {
                        echo $row2[0].". ".$row2[1]." ".$row2[2]."<br>";
                    }
                }
            ?>
        </div>

        <div id="prawy">
            <img src="drapieznik.jpg" alt="Wilki">
        </div>

        <footer>
            <a href="https://pl.wikipedia.org" target="_blank">Poczytaj o zwierzętach na Wikipedii</a>, autor strony: <a href="https://ee-informatyk.pl/" target="_blank" style="color: #fff;">EE-Informatyk.pl</a>
        </footer>
    </body>
</html>

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

header {
    background: DarkCyan;
    color: white;
    text-align: center;
    padding: 20px;
}

#formularz {
    background: lightseagreen;
    text-align: center;
    padding: 60px;
}

#lewy,
#srodkowy {
    background: Teal;
    color: white;
    text-align: center;
    height: 350px;
    width: 25%;
    float: left;
}

#prawy {
    background: Teal;
    height: 350px;
    width: 50%;
    float: left;
}

footer {
    background: darkcyan;
    color: white;
    padding: 40px;
    clear: both;
}

ul {
    border: 4px dotted rgb(127,255,212);
    list-style-position: inside;
}

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ę