Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 20.10.2016
Сообщений: 18
MySQL

Удаление из базы данных через форму и php методом checkbox

20.10.2016, 02:16. Показов 2990. Ответов 6

Студворк — интернет-сервис помощи студентам
Имеем форму:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 <form action="news_drop.php" method="post">
<? 
 
$result = mysql_query("SELECT * FROM news");      
$myrow = mysql_fetch_array($result);
 
do 
{
printf ("<p><input name='id' type='radio' value='%s'><label> %s</label></p>",$myrow["id"],$myrow["title"]);
}
 
while ($myrow = mysql_fetch_array($result));
?>
 
<p> <input name="submit" type="submit" id="submit" value="Удалить новость"></p>
 
</form>
и на другой странице продолжение в виде:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<?include ("include/cfg.php");
if (isset($_POST['id'])) {$id = $_POST['id'];}
if (isset($id))
{
$result = mysql_query ("DELETE * FROM news WHERE id='$id'");
 
if ($result == 'true') {echo "<p>Ваша заметка успешно удалена!</p>";}
else {echo "<p>Ваша заметка не удалена!</p>";}
 
 
}        
else 
 
{
echo "<p>Вы запустили данный фаил без параметра id и поэтому, удалить заметку невозможно (скорее всего Вы не выбрали радиокнопку на предыдущем шаге).</p>";
}
         
         
         
         ?>
теперь вопрос, не могу никак понять и найти, как после изменения параметра radio на checkbox, что бы он удалял все выделенные записи из базы данных?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.10.2016, 02:16
Ответы с готовыми решениями:

Удаление данных из MySQL через форму PHP
Доброго времени суток! Такая загвоздка. Есть сайт и таблица со статьями. На сайте есть форма для управления таблицей, то есть...

Checkbox удаление записей из базы данных
PHP никаких ошибок не выдаёт, записи из базы загрузились, checkbox-ы появились, выделяю несколько, нажимаю &quot;удалить&quot; и ничего не...

Использование Checkbox / PHP и базы данных
Доброго времени суток Нужна помощь вот в каком деле есть список домов я его вывожу с чекбоксом вот как это я делаю поле CHECKED bit ...

6
94 / 94 / 68
Регистрация: 26.03.2015
Сообщений: 248
20.10.2016, 06:47
А в чем трудность? Просто меняете SQL-запрос на удаление:
PHP
1
mysql_query('DELETE FROM news WHERE id IN ('.mysql_real_escape_string(implode(', ', $_POST['id'])).')');
1
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
20.10.2016, 06:55
alx_box, имя должно быть уникальным (можете значение id приклеить) или используйте такое обозначение имени: id[] (и далее уже запрос, похожий на тот, что выше показали).

Цикл у вас неправильный. Используйте просто while.
1
0 / 0 / 0
Регистрация: 20.10.2016
Сообщений: 18
20.10.2016, 14:36  [ТС]
То есть вместо этого:
PHP
1
2
3
4
5
{
$result = mysql_query ("DELETE * FROM news WHERE id='$id'");
 
if ($result == 'true') {echo "<p>Ваша заметка успешно удалена!</p>";}
else {echo "<p>Ваша заметка не удалена!</p>";}
вставить
PHP
1
mysql_query('DELETE FROM news WHERE id IN ('.mysql_real_escape_string(implode(', ', $_POST['id'])).')');
0
94 / 94 / 68
Регистрация: 26.03.2015
Сообщений: 248
20.10.2016, 15:07
Лучший ответ Сообщение было отмечено alx_box как решение

Решение

alx_box, проверку результата на true можно и оставить. Просто замените SQL-выражение, передаваемое в функцию mysql_query(). И замените значение атрибута name тега input с id на id[], как сказал miketomlin, иначе в POST'е будет передаваться не массив со значениями, а строка с последним из них.

Должно получиться примерно следующее:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
include ("include/cfg.php");
 
if (! empty($_POST['id'])) {
    $id = $_POST['id'];
}
 
if (isset($id)) {
    $result = mysql_query('DELETE FROM news WHERE id IN ('.mysql_real_escape_string(implode(', ', $id)).')');
 
    if ($result === true) {
        echo "<p>Выбранные заметки успешно удалены!</p>";
    } else {
        echo "<p>Выбранные заметки не удалены!</p>";
    }
} else {
echo "<p>Вы запустили данный фаил без параметра id и поэтому, удалить заметку невозможно (скорее всего Вы не выбрали радиокнопку на предыдущем шаге).</p>";
}
1
0 / 0 / 0
Регистрация: 20.10.2016
Сообщений: 18
20.10.2016, 15:17  [ТС]
ns16, Огромное спасибо! Заработало!
А можешь сразу и книжку порекомендовать умную по php или еще что-то?
0
94 / 94 / 68
Регистрация: 26.03.2015
Сообщений: 248
20.10.2016, 16:42
Лучший ответ Сообщение было отмечено alx_box как решение

Решение

alx_box, лично я изучал PHP по русскоязычной документации http://php.net/manual/ru. По мне так это самый лучший учебник
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.10.2016, 16:42
Помогаю со студенческими работами здесь

Удаление поста из БД через php форму
Такая задача: необходимо добавить кнопку удаления к каждому посту и при нажатии на нее удалять запись из базы. Подскажите в чем у меня...

Добавление данных через форму в таблицу базы данных MS SQL
Здравствуйте! Я делаю форму для добавления записи в таблицу базы данных, созданную в MS SQL 2008. В таблице три поля...

Удаление данных из базы посредством PHP
Доброго времени суток! Прежде, чем начнете меня ругать, хочу сказать, что курил очень много форумов, сайтов и других ресурсов, но так и не...

Php и добавление в базу данных через форму - PHP БД
Привет. Есть вопрос не могу понять почему данные не добавляются в таблицу. вроде все верно. &lt;h2...

PHP и БД. Отправка данных из checkbox в бд (желательно через запятую)
Подскажите, где ошибка, пожалуйста.. . Данные вообще не заносятся в бд из checkbox. И как сделать , чтобы через запятую заносились в бд? ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru