Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 21.01.2014
Сообщений: 38

Удаление записи не по id (ajax)

18.09.2019, 13:20. Показов 1452. Ответов 3
Метки ajax, php (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Подскажите, пожалуйста. У меня есть функция удаления записей из БД по id с alert об успешном удалении записи. Моя задача теперь заключается в том, чтобы в alert передавать поле Name для каждого id. Я вижу два варианта. Первый - передать в ajax по цепочке не только id из .php-файла, но и поле Name. Чтобы потом его значения можно было занести в переменную в jquery и вставить её в alert. И второй - передавать не id, а Name. Я пошёл по второму пути, поскольку он легче для моего понимания. Но проблема в том, что если все id поменять на Name, то функция удаления будет работать только для имён, состоящих исключительно из цифр. То есть любая буква в имени, и кнопка "Удалить" перестаёт быть функциональной. Подскажите, пожалуйста, как можно решить данную проблему. Спасибо!

index.php:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
    include 'db.php';   // Подключение БД
    
    // Временная зона, используемая по умолчанию
    $timezone = date_default_timezone_get();
        date_default_timezone_set($timezone);
 ?>
 
<!DOCTYPE html>
<html>
    <head>
        <meta charset = "utf-8">
        <title>Список книг</title>        
        <script src = "js/delete.js"></script>
        <script src = "js/jquery-3.4.1.min.js"></script>    
        <link rel = "stylesheet" href = "css/bootstrap.min.css">        
        <style> body { background: #333; } </style>
    </head>
    <body>
        <p><br /></p>
        <div class = "container">
            <p><h3><font color = "white">Список книг в нашей библиотеке:</font></h3></p>      
            
            <!-- Вывод данных из БД в виде таблицы: заголовочная строка -->
            
            <table class = "table table-bordered table-dark">  
                <tr>
                    <th align = "center">Название</th>
                    <th align = "center">Дата добавления</th>
                    <th align = "center">Краткое описание</th>
                    <th align = "center">Количество страниц</th>
                    <th align = "center">Стоимость (руб)</th>
                </tr>
                
            <!-- Запрос и алгоритм на отображение данных из БД -->    
    <?php 
    $query = "SELECT *, date_format(Add_date,'%d.%m.%Y') as Add_date FROM books";   // Запрос
 
    $select = mysqli_query($con,$query);    // Выполняет запрос к БД
 
    while ($result = mysqli_fetch_array($select)) {     // Возвращает массив, соответствующий выбранной строке
    
        $date1 = $result['Date_now'];                           // Дата создания записи в БД
        $date2 = date('Y-m-d H:i:s');                           // Текущая дата в выбранном формате
        $date3 = round((strtotime($date2) - strtotime($date1)) /60);    // Получение разницы в минутах
        
        if ($date3 == 0) {
            $z = "Добавлена только что";
        } else if (($date3 > 0) && ($date3 < 60)) {
            $z = "Добавлена ".$date3." минут назад";
        } else if (($date3 > 60) && ($date3 < 86400)) {
            $z = "Добавлена больше часа назад";
        } else {
            $z = "Добавлена больше суток назад";
        }   ?>
        
            <!-- Вывод данных из БД в виде таблицы: строки данных -->
 
                <!-- Тут было <tr id = "delete<?php echo $result['id']; ?>"> -->
                <tr id = "delete<?php echo $result['Name']; ?>">    <!-- В контейнере для строки - Name, по которому и будет удаление  -->      
                    <td align = "center"><?php echo $result['Name']; ?></td>
                    <td align = "center"><?php echo $result['Add_date']; ?></td>
                    <td align = "center"><?php echo $result['Short_description']; ?></td>
                    <td align = "center"><?php echo $result['Amount_of_pages']; ?></td>
                    <td align = "center"><?php echo $result['Cost']; ?></td>
                    <td align = "center"><font size = "2px"><?php echo $z; ?></font></td>
                    
                    <!-- Кнопка удаления записи из БД (по Name). По нажатию - выполнение скрипта deleteAjax(Name) -->
                    <!-- Тут было: $result['id'] -->
                    <td align = "center"><button onclick = "deleteAjax(<?php echo $result['Name']; ?>)" class = "btn btn-danger">Удалить</button></td>
                </tr>
                
    <?php } ?>
            </table>
        </div>                          
    </body>
</html>
delete.php:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
<?php
 
  include 'db.php'; // Подключение БД
  
  /* Тут было
    $id = $_POST['delete_id'];  // Пришедшие данные
    $query = mysqli_query($con,"DELETE FROM books WHERE id = '$id'");
  */
  $Name = $_POST['delete_Name'];    // Пришедшие данные
  $query = mysqli_query($con,"DELETE FROM books WHERE Name = '$Name'"); // Отправляем в запрос, который будет удалять запись
 
 ?>
delete.js:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
function deleteAjax(Name){  // было function deleteAjax(id)
 
    if(confirm('Подтвердите удаление')){     // Если выведен confirm
    
        $.ajax({                            // Без перезагрузки страницы
            
            type: 'POST',                   // Передать
            url: 'delete.php',                         // В .php-файл для обработки 
            data: {delete_Name: Name},          // было data: {delete_id: id}
            
            success: function(data) {            // Если ошибок не возникло
                
                if (typeof(data) != "undefined" && data !== null) { // Проверка на наличие данных
                    
                    $('#delete' + Name).hide('slow');               // было $('#delete' + id).hide('slow');
                    alert("Книга '" + Name + "' успешна удалена");  // было alert("Книга '" + id + "' успешна удалена");
                    
                } else alert("Запись не была удалена. Что-то пошло не так");  // Либо сообщить об ошибке
 
            }
        });
    }
}
db.php:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
    error_reporting(E_ALL);             // Включение в отчёт любой возможной ошибки
    ini_set('display_errors', 'on');    // Отображение ошибок включить
    
    // Данные для поключения к БД: имя сервера, пользователя, пароль и название БД
    
    $servername = "localhost";
    $username = "root";
    $password = "";
    $dbname = "testdb";
 
    $con = new mysqli($servername, $username, $password, $dbname);  // Подключает к БД с указанными данными
    mysqli_query($con, "SET NAMES 'utf8'");             // Выполняет запрос на создание имён в указанной кодировке
 
    if ($con->connect_error) {                                          // Если возникла ошибка
        die("Возникла ошибка при соединении: " . $con->connect_error);   // Вывести её
    }
?>
Миниатюры
Удаление записи не по id (ajax)  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.09.2019, 13:20
Ответы с готовыми решениями:

Удаление записи из бд с использованием ajax. подскажите что не так
подключение через pdo $stmt = $pdo-&gt;query(&quot;SELECT * FROM bookmark&quot;); $stmt-&gt;setFetchMode(PDO::FETCH_ASSOC); while($row =...

Реализовать удаление из таблицы записи нажатием на чекбокс с использованием ajax
Существует база данных mydb, в ней таблица table с полями id и name. На экран выводится содержимое поля name. Возле каждого name - чекбокс....

ListView: добавление записи, выбор записи, удаление записи
на форме есть три текст бокса: textbox1(имя), textbox2(фамилия), textbox3(отчество), textbox4(выбранное) кнопка Button1(добавить),...

3
 Аватар для esculap_ra
462 / 265 / 55
Регистрация: 22.08.2010
Сообщений: 1,204
Записей в блоге: 4
18.09.2019, 18:03
Ну так включи параметры, типа
PHP
1
2
3
4
data: {
delete_name: name,
delete_id: id
}
И лови на сервере.

Добавлено через 9 минут
JavaScript
1
2
3
4
function deleteAjax(id){
name = $("tr#"+id+":first-child").text();
.....//тут включаешь обработчик аякса
}
0
0 / 0 / 0
Регистрация: 21.01.2014
Сообщений: 38
18.09.2019, 20:48  [ТС]
Запись удаляется, но с сообщением ''. То есть в alert написано "...' " + name + " ' ...". То есть вместо имени там пустое значение (Скрин прилагаю)

index.php:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
<tr id = "delete<?php echo $result['id']; ?>">  
    <td align = "center"><?php echo $result['Name']; ?></td>
    <td align = "center"><?php echo $result['Add_date']; ?></td>
    <td align = "center"><?php echo $result['Short_description']; ?></td>
    <td align = "center"><?php echo $result['Amount_of_pages']; ?></td>
    <td align = "center"><?php echo $result['Cost']; ?></td>
    <td align = "center"><font size = "2px"><?php echo $z; ?></font></td>
                                
    <td align = "center">
               <button onclick = "deleteAjax(<?php echo $result['id']; ?>)" class = "btn btn-danger">Удалить</button>
       </td>
</tr>
delete.php:

PHP
1
2
3
4
5
6
7
8
9
10
<?php
 
  include 'db.php'; 
 
  $id = $_POST['delete_id'];    
  $name = $_POST['delete_name'];
 
  $query = mysqli_query($con,"DELETE FROM books WHERE id = '$id'"); 
 
 ?>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
function deleteAjax(id){  // Функция удаления
 
    name = $("tr#"+id+":first-child").text();
    
    if(confirm('Подтвердите удаление')){     
    
        $.ajax({                            
            
            type: 'POST',                   
            url: 'delete.php',          
            data: { delete_id: id,
                   delete_name: name
            },          
            
            success: function(data) {            
                
                if (typeof(data) != "undefined" && data !== null) { 
                    
                    $('#delete' + id).hide('slow');                 
                    alert("Книга '" + name + "' успешна удалена");   
                    
                } else alert("Запись не была удалена. Что-то пошло не так");  
 
            }
        });
    }
}
Изображения
 
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
19.09.2019, 00:03
Цитата Сообщение от Rvach_01 Посмотреть сообщение
name = $("tr#"+id+":first-child").text();
JavaScript
1
var name = ..................
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.09.2019, 00:03
Помогаю со студенческими работами здесь

Удаление загрузочной записи о Windows8.1 и удаление самой Windows 8.1 при наличии двух ОС
На ноутбуке на разделе C Windows XP ,установил Windows 8.1 на логический раздел E.Теперь хочу удалить 8.1 и установить туда 7.В БИОСе...

Добавление и удаление записи, поиск записи с максимальной зарплатой, сортировка по алфавиту
Помогите, пожалуйста!:help: Очень нужно сделать до 26!(а если не сложно, то еще и с комментариями :-Добавлено через 27 минут если вы...

Удаление или изменение записи невозможно, в таблице имеются связанные записи
Доброй ночи. при удалении из родительской таблицы появляется ошибка &quot;удаление или изменение записи невозможно в таблице имеются связанные...

Массив структур: добавление записи, удаление записи, поиск по одному или нескольким из полей
Необходимо реализовать базу данных с полями «Фамилия», «Имя», «Отчество», «Пол», «Год рождения». Каждая запись должна представлять собой...

Удаление записи из массива записи или файла
Доброго времени суток... Задача стоит такая. Есть массив записей, прочитали из файла или так создали, неважно... Каждая запись имеет...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru