Простое удаление записи SQL - не работает

Все, что я пытаюсь сделать, это создать простую текстовую форму и удалить запись из базы данных sql. Он возвращает, что запись удален, но на самом деле никогда не удаляет запись.

переменныеremove.php:

Простое удаление записи SQL - не работает

изображение формы html:

Простое удаление записи SQL - не работает

remove.php:

Простое удаление записи SQL - не работает

remove.php:

require('variablesremove.php');

$user = "#"; 
$password = "#"; 
$host = "localhost"; 
$database= "#";

$connection= mysqli_connect ($host, $user, $password);
if (!$connection) {
    die ('Could not connect:' . mysql_error());
}

mysqli_select_db($database, $connection);

$deleterow = "DELETE FROM licenses WHERE serialNumber='$serialNumber'";

if ($deleterow !== FALSE) {
    echo("The row has been deleted.");
} else {
    echo("The row has not been deleted.");
}

Переменная, содержащая серийный номер, - $id, а не $serialNumber. Проверьте строку удаления sql.

Karlo Kokkak 20.05.2018 08:25

вы не запускаете запрос или не определяете $serialNumber

user9487972 20.05.2018 08:28

Я исправил $ id $ deleterow = "УДАЛИТЬ ИЗ лицензий WHERE serialNumber = '$ id'";

Douglas Littlefield 20.05.2018 08:31

Закрепите держатель ссылки серийного номера на $ id и выполните оператор запроса на основе приведенного ниже примера, и вы должны быть готовы к работе! @DouglasLittlefield

Sharkes Monken 20.05.2018 08:35
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
4
287
5
Перейти к ответу Данный вопрос помечен как решенный

Ответы 5

Ответ принят как подходящий

Вам нужно использовать mysqli_query() для выполнения вашей команды удаления.

$deleteRow = "DELETE FROM licenses WHERE serialNumber='$id'";

if (mysqli_query($connection, $deleteRow)) {
  echo "Record deleted successfully";
} else {
  echo "Error deleting record: " . mysqli_error($conn);
}

mysqli_close($conn);

mysqli_query ($ deleterow) = "УДАЛИТЬ ИЗ лицензий, ГДЕ serialNumber = '$ serialNumber'"; ?

Douglas Littlefield 20.05.2018 08:28

Обновлен пример выше

Sharkes Monken 20.05.2018 08:29

Вы можете использовать это в качестве примера -

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// Create connection
$conn = mysqli_connect($servername, $username, $password, $dbname);
// Check connection
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}

// sql to delete a record
$sql = "DELETE FROM MyGuests WHERE id=3";

if (mysqli_query($conn, $sql)) {
    echo "Record deleted successfully";
} else {
    echo "Error deleting record: " . mysqli_error($conn);
}

mysqli_close($conn);
?>

Ошибка при удалении записи: Неизвестный столбец '00000000f5f409ce' в 'where clause' $ sql = "УДАЛИТЬ ИЗ лицензий WHERE serialNumber = $ id";

Douglas Littlefield 20.05.2018 08:36

Интегрируйте вашу БД

Md Rashed Pervez 20.05.2018 08:39
...
mysqli_select_db($database, $connection);

$deleterow = "DELETE FROM licenses WHERE serialNumber = '$serialNumber'";

if (mysqli_query($conn, $deleterow)) {
    echo("The row has been deleted.");
} else {
    echo("The row has not been deleted.");
}
...

Напишите, пожалуйста, правильный ответ. Простое добавление кода здесь в лучшем случае мало поможет или может быть неправильно понято и вредно в худшем. Спасибо за внимание.

Rann Lifshitz 20.05.2018 08:49

Если вы проверите, что мой ответ был единственным, который не был скопирован, все вышеперечисленное помещало общие ответы и редактировало их, фактически я был первым, кто поместил переменную $ deleterow в правильную функцию, в то время как все остальные ответы являются общими. И еще одна деталь: принятый ответ скопировал переменную $ deleterow в правильную функцию после того, как я опубликую решение.

ℛɑƒæĿᴿᴹᴿ 20.05.2018 09:01

Справедливо. Если вы хотите, чтобы вас проголосовали за, вам придется приложить дополнительные усилия, чтобы опубликовать хороший ответ, независимо от того, что другие копируют вас. Просто пытаюсь помочь приятелю. Проверьте это обсуждение по этому вопросу: meta.stackexchange.com/questions/17204/… И чтобы показать, что я понял вашу точку зрения, я также проголосовал за ваш ответ.

Rann Lifshitz 20.05.2018 09:12

Вы отличный человек, я очень благодарен вам за ваш голос, и я учту все ваши советы, потому что вы однозначно цените хорошее функционирование сайта.

ℛɑƒæĿᴿᴹᴿ 20.05.2018 09:18

Вы также можете подумать о том, чтобы проголосовать за некоторые из моих ответов по дороге;)

Rann Lifshitz 20.05.2018 09:23

Я дал два сегодня, и я дам больше в течение недели, если вы тоже сможете это сделать, я буду рад. Обнимаю!

ℛɑƒæĿᴿᴹᴿ 20.05.2018 09:31

Я просмотрю твои посты. Проголосую за хорошие ответы и вопросы. Заботиться :)

Rann Lifshitz 20.05.2018 09:33

Фактически вы должны использовать параметризованный запрос для запуска этого оператора.

В существующей форме он подвержен атакам с использованием SQL-инъекций.

if ($deleterow = $mysqli->prepare("DELETE FROM licenses WHERE serialNumber = ?") {
    $deleterow->bind_param("s", $id);
    if ($deleterow->execute()) {
        printf("The row has been deleted.\n");
    }else{
        echo "Error deleting record: " . mysqli_error($conn);
    }
} else {
    printf("Error preparing the query: %s\n",$deleterow);
}

$mysqli->close();

Спасибо всем за помощь!

Вот рабочее решение!

<?php
require('variablesremove.php');
$user = "#"; 
$password = "#"; 
$host = "#"; 
$database = "#";

$connection= mysqli_connect ($host, $user, $password);

if (!$connection)

{

die ('Could not connect:' . mysql_error());

}

mysqli_select_db($connection, "$database") or die ("Couldn't select the database."); 

$deleteRow = "DELETE FROM licenses WHERE serialNumber='$id'";

if (mysqli_query($connection, $deleteRow)) {
  echo "Record deleted successfully";
} else {
  echo "Error deleting record: " . mysqli_error($connection);
}

mysqli_close($connection);
?>

Другие вопросы по теме