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

Jak usunąć kwerendą dane tabeli?

VPS Starter Arubacloud
0 głosów
243 wizyt
pytanie zadane 22 lutego 2018 w PHP przez Śwież4k Bywalec (2,570 p.)
edycja 22 lutego 2018 przez Śwież4k

Siema, chciałem stworzyć kwerendę, która będzie usuwać rekordy z bazy wyświetlone na stronie internetowej.

Jednak php służy chyba tylko do pobierania danych z formularza i nie wiem jak przy pomocy przycisku, w prosty sposób usunąć rekord z bazy. Proszę o pomoc w rozwiązaniu problemu i pozdrawiam!

while(list($id,$typ,$przedmiot,$opis,$data,$dodano)=mysqli_fetch_row($rezultat))
      {
      echo "<tr><form method='post' action='delete.php'>"."<td name='przedmiot'>".$przedmiot."</td>"."<td name='typ'>".$typ."</td>"."<td name='opis' value='$opis'>".$opis."</td>"."<td name='data' style='color:brown'><b>".$data."</b></td>"."<td name='dodano'>".$dodano."</td>";
	  if($_SESSION['mod']==1)
	  {
		  echo "<td><input style='padding: 5px;' type='submit' value='Usuń'></td></form>";
	  }
	  echo "</tr>";

      }

      echo  "</table>";
<?php
session_start();
require_once "connect.php";
$polaczenie = new mysqli($host,$db_user,$db_password,$db_name);
if(isset($_POST['opis']))
{
  $dodano = $_SESSION['user'];
  $przedmiot = $_POST['przedmiot'];
  $typ = $_POST['typ'];
  $opis =  $_POST['opis'];
  $data = $_POST['date'];
  if($polaczenie -> query("DELETE FROM zadania WHERE opis='$opis'"))
  {
    $_SESSION['ok'] = "Poprawnie usunięto rekord z bazy";
    header("Location: zalogowany.php");
  }
  else {
    echo "Zjebało się";
    echo $polaczenie->error;
  }
} else {
  echo "ni ma :9";
}
?>

1 odpowiedź

0 głosów
odpowiedź 22 lutego 2018 przez Arkadiusz Waluk Ekspert (287,550 p.)
wybrane 23 lutego 2018 przez Śwież4k
 
Najlepsza
Z PHP możesz wysłać dowolne zapytanie do bazy danych. Wystarczy więc wysłać takie, które usunie odpowiedni rekord (DELETE).
komentarz 22 lutego 2018 przez Śwież4k Bywalec (2,570 p.)
No za nic mi nie chce pobrać tych komórek z tabeli. Mam ustawione tak <td name="przedmiot">$przedmiot</td>. Plik php, który ma zadanie dany rekord usunąć nie widzi przesłanych danych, czyli $_POST['przedmiot']
komentarz 22 lutego 2018 przez Arkadiusz Waluk Ekspert (287,550 p.)
Bez kodu ciężko cokolwiek powiedzieć.
komentarz 22 lutego 2018 przez Śwież4k Bywalec (2,570 p.)
jest już w poście
komentarz 22 lutego 2018 przez Arkadiusz Waluk Ekspert (287,550 p.)
Skąd skrypt ma wiedzieć który rekord usunąć? Odczytujesz różne dane z tablicy POST, w tym $_POST['opis'], ale tego tam nie ma. W formularzu masz tylko jeden input i to jest przycisk, pozostałe rzeczy - np. elementy tabeli - nie są przesyłane.

Przy okazji dodam, że takie wstawianie danych do zapytania jest niebezpieczne, naraża Cię na atak sql injection, który może powodować np. wyciek bazy danych czy usunięcie danych.
komentarz 22 lutego 2018 przez Śwież4k Bywalec (2,570 p.)
To jak to zrobić? Przesłać dane do formularza, a z formularza do pliku zewnetrznego?
komentarz 22 lutego 2018 przez Arkadiusz Waluk Ekspert (287,550 p.)
Na formularzu możesz dodać np. input typu hidden - nie będzie widoczny, ale będzie przesyłał jakieś dane. Albo nawet do tego przycisku możesz dorzucić id (czy pole po którym usuwasz) i też to sprawdzać.
komentarz 22 lutego 2018 przez Śwież4k Bywalec (2,570 p.)

Albo nawet do tego przycisku możesz dorzucić id (czy pole po którym usuwasz) i też to sprawdzać.

Nie rozumiem co masz na myśli 

komentarz 22 lutego 2018 przez Arkadiusz Waluk Ekspert (287,550 p.)
W bazie w większości przypadków powinieneś mieć kolumnę jak id, unikalny identyfikator. Na formularzu masz przycisk, który służy do wysłania formularza. Jeśli dasz mu nazwę i podstawisz pod value np. ten identyfikator to możesz to odczytać w PHP w $_POST, zrobić zapytanie z takim warunkiem i usunąć rekord. Obecnie próbujesz kasować po $_POST['opis'], nie wiem czy to dobry pomysł, opis jest unikalny w bazie? Jeśli nawet tak, to i tak dla bazy danych powinno być szybciej i wygodniej zrobić warunek po liczbie - kluczu podstawowym.
komentarz 23 lutego 2018 przez Śwież4k Bywalec (2,570 p.)
działa pozdro

Podobne pytania

0 głosów
1 odpowiedź 1,256 wizyt
pytanie zadane 6 maja 2018 w PHP przez Damian Prymus Początkujący (380 p.)
0 głosów
1 odpowiedź 157 wizyt
0 głosów
1 odpowiedź 156 wizyt
pytanie zadane 20 lipca 2016 w PHP przez DaltooN Początkujący (430 p.)

92,454 zapytań

141,262 odpowiedzi

319,089 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...