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

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

20.10.2016, 02:16. Показов 3021. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru