Stránka 1 z 1

přidávání prvků pomocí PHP do databáze  Vyřešeno

Napsal: 16 lis 2014 18:22
od Fantomas
Ahoj,

mám formulář:

Kód: Vybrat vše

<form action="./pridejOtazkuDb.php" method="get">
    <input type="text" name="otazka" value="" placeholder="Otázka">
    <input type="text" name="odpoved" value="" placeholder="Odpověď">
           
     <input type="submit" value="Odeslat">
</form>


a PHP kód, který má odeslat z formuláře Otázku a správnou odpověď:

Kód: Vybrat vše

<?php
header('Content-Type: text/html; charset=utf-8');

$server = "localhost";
$databaze = "db";
$uzivatel = "fantomas";
$heslo = "fantom";


if (mysql_connect($server, $uzivatel, $heslo)) {

    if (mysql_select_db($databaze)) {


        $pridej = "INSERT INTO Otazky VALUES(NULL,'$GET[otazka]','$GET[odpoved]')";
        $proved = mysql_query($pridej);
               
       
        if ($proved) {
         
            header("location:./pridejOtazkuForm.php");
        }else{
            echo 'nastala chyba při zapisování do DB';
        }

     
       
       
    } else{
        echo 'nepřipojeno';
    }
} else {
  echo 'chyba';
}
?>


PHP soubor nevyhodí žádnou chybu, vrátí mě tedy zpět na formulář. Problém však je na straně hostingu, kde se mi do tabulky přidá jen ID (které má být v první kolonce a v PHP tedy dávám hodnotu NULL, neboť se mi automaticky přidává), další 2 sloupce však jsou prázdné (viz obr.).

Znakovou sadu mám správně, ale nechápu kde je chyba. Díky za radu.

Re: přidávání prvků pomocí PHP do databáze

Napsal: 16 lis 2014 22:34
od omilis
Pokud vkládáš něco do databáze, tak je dobré vyjmenovat názvy sloupců, tím si ujasníš pořadí

Kód: Vybrat vše

INSERT INTO Otazky(otazka,spravnaOdpoved) VALUES('$GET[otazka]','$GET[odpoved]')

Začal bych kontrolou, zda $GET[otazka] něco obsahuje. PHP moc neznám ale očekával bych tam spíše $GET["otazka"] (všimni si těch uvozovek). Celkově máš ty uvozovky nějaké zmatené.

Mimochodem, vždy když komunikuješ s databází, tak bys měl používat parametrizované dotazy namísto spojování řetězců.

Re: přidávání prvků pomocí PHP do databáze

Napsal: 19 lis 2014 07:52
od Fantomas
problém byl v $_GET, napsal jsem totiž $GET