• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Wstawianie rekordów do bazy

Object Storage Arubacloud
0 głosów
239 wizyt
pytanie zadane 3 maja 2020 w SQL, bazy danych przez Młody programista Obywatel (1,200 p.)

Mam problem, bo nie wiem dlaczego nie wstawia mi rekordów do bazy. Nie mogę znaleźć błędu, nie wyświetla komunikatu, formularz normalnie się wysyła.

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <link rel="stylesheet" href="style.css">
    <title>Projekt</title>
</head>

<body>
<header>
    <section>
        <nav>
            <div class="title">
                Panel Admina
            </div>
            <center>
                <div class="menu">
                    <button><a href="index.php">Strona główna</a></button>
                    <button><a href="index.php?mode=sportowcy">Sportowcy</a></button>
                    <button><a href="index.php?mode=dyscyplina">Dyscyplina</a></button>
                    <button><a href="index.php?mode=dodaj">Dodaj</a></button>
                    <button><a href="index.php?mode=mody">Modyfikacja</a></button>
                    <button><a href="index.php?mode=ocena">Ocena</a></button> 
                </div>
        </center> 
           
        </nav>
    </section>
</header>
    <?php 
        $connect = new mysqli('localhost', 'root', '', 'projekt');

        if( $connect ->connect_errno) {
            echo "wystapil blad ".$connect ->connect_errno;
            echo " nazwa bledu ".$connect ->connect_error;
        }
        //ustawienie schematu kodowania utf8
        $query_utf="SET CHARSET utf8";
        $connect->query($query_utf);

        if(isset($_GET['mode'])){
            if($_GET['mode']=='sportowcy'){
                //pobieram wartosci, pozniej lekka konfiguracja
                $sportowiec = "SELECT * FROM sportowiec";
                $result=$connect->query($sportowiec);
                $plec='SELECT DISTINCT plec FROM plec';
                $wynik=$connect->query($plec);
                $status='SELECT DISTINCT status FROM status';
                $wynik2=$connect->query($status);
                echo '
                <center>
                <br>
                <form action="index.php?mode=sportowcy" action="post">
                Imie:<input type="text" name="imie"><br><br>
                Nazwisko:<input type="text" name="nazwisko"><br><br>
                Wiek:<input type="number" name="wiek"><br><br>
                Płeć:<select name="plec">';
                while($typ1=$wynik->fetch_object()){
                    echo"<option name='$typ1->plec' value='$typ1->plec'> $typ1->plec</option>";
                }
                echo'</select><br><br>
                Status:<select name="status">';
                while($typ2=$wynik2->fetch_object()){
                    echo"<option name='$typ2->status' value='$typ2->status'> $typ2->status</option>";
                }
                echo'</select><br><br>
                Trener:<input type="text" name="trener"><br><br>
                <input type="submit" name="dodaj" value="Dodaj"><br><br>
                </form>
                ';
                
                if(isset($_POST['submit'])){

                    $imie=$_POST['imie'];
                    $nazwisko=$_POST['nazwisko'];
                    $wiek=$_POST['wiek'];
                    $plec=$_POST['plec'];
                    $status=$_POST['status'];
                    $trener=$_POST['trener'];

                    $AddSportowiec="INSERT INTO sportowiec (imie, nazwisko,wiek,plec_id,status_id,trener) 
                    VALUES ('$imie','$nazwisko','$wiek','$plec','$status','$trener')";
                    $connect->query($AddSportowiec);
                   

                }
            
            }
           
        }
        $connect -> close(); 


       
    ?>
</body>

</html>

1 odpowiedź

+1 głos
odpowiedź 4 maja 2020 przez bwaluk Mądrala (5,440 p.)
wybrane 4 maja 2020 przez Młody programista
 
Najlepsza

Masz kilka błędów w kodzie PHP/HTML i jeden w konstrukcji SQL (również bardziej od strony PHP). Ale do początku.

W znaczniku formularza (linijka 56) użyłeś błędnego atrybutu (dwa razy action zamiast action i method). Poniżej poprawnie:

<form action="index.php?mode=sportowcy" method="post">

Drugi element to błędny IF (linijka 75). Nie pytasz o submit tylko o konkretnego submita (czyli jego name). Poniżej poprawny IF:

if(isset($_POST['dodaj']))

Trzeci błąd/błędy to zła obsługa OPTIONÓW (i za krótki SELECT) oraz przekazywanie błędnej wartości do INSERTA. Najpierw trzeba pobierać IDki z tabel - gdyż insertujesz później (do tabeli sportowcy) IDki płci i statusu, a nie nazwy.

Więc SELECTY popraw tak (linijki 49-51):

$plec='SELECT DISTINCT * FROM plec';
$wynik=$connect->query($plec);
$status='SELECT DISTINCT * FROM status';

Lub bardziej bezpiecznie:
 

$plec='SELECT DISTINCT plec_id, plec FROM plec';
$wynik=$connect->query($plec);
$status='SELECT DISTINCT status_id, status FROM status';

I na koniec - trzeba poprawić OPTIONY (linijki 62 i 67) - do VALUE musisz dawać wartość z kolumny ID a nie z NAME:
 

echo"<option name='$typ1->plec' value='$typ1->plec_id'> $typ1->plec</option>";
echo"<option name='$typ2->status' value='$typ2->status_id'> $typ2->status</option>";

I powinno działać!

komentarz 4 maja 2020 przez bwaluk Mądrala (5,440 p.)
Generalnie wrzuciłeś to pytanie do złej kategorii :)
komentarz 4 maja 2020 przez Młody programista Obywatel (1,200 p.)
Dzięki, z kategoriami to właśnie się zastanawiałem :)

Podobne pytania

0 głosów
1 odpowiedź 414 wizyt
pytanie zadane 13 listopada 2018 w SQL, bazy danych przez Micheall Początkujący (420 p.)
0 głosów
1 odpowiedź 136 wizyt
pytanie zadane 31 października 2016 w PHP przez Q_Nick Mądrala (5,010 p.)
0 głosów
2 odpowiedzi 13,374 wizyt

92,579 zapytań

141,432 odpowiedzi

319,662 komentarzy

61,963 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...