Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557

При удалении файла так же удалить информации, занесенную вместе с ним

05.01.2014, 23:10. Показов 1380. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. В page.php при загрузке файла на сервер указывается информация о нём и заносится в таблицу files. Затем на index.php можно эту информацию увидеть. Так же можно по нажатию кнопки удалить файл. ВОТ тут то и проблема, не могу сделать так что бы удалить информацию о нем, при нажатии этой же кнопки. (Знаю что нужно делать через DELETE, но не знаю как правильно).

page.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
    <p>
    <input type='hidden' name='name' value='$_SESSION[login]' />
    <input type='hidden' name='id' value='$poluchatel_file' />
    </p>
 
     <p align="center"><label>Ваша тема:<br></label>
     <input name="tema" type="text" size="45" maxlength="100"></p>
 
     <p align="center"><label>Выберите руководителя:</label><br>
     <select name="rukov">
     <option select></p>
     <option value="Мокроусов М.Н.">Мокроусов М.Н.
     <option value="Телегина М.В.">Телегина М.В.
     </select><br><p>
 
     <p align="center"><label>Выберите консультанта:</label><br>
     <select name="konsul">
     <option select></p>
     <option value="Мокроусов М.Н.">Мокроусов М.Н.
     <option value="Телегина М.В.">Телегина М.В.
     </select><br><p>
 
     <p align="center"><label>Выберите язык программирования:</label><br>
     <select name="yazik">
     <option select></p>
     <option value="Delphi">Delphi
     <option value="C++">С++
     </select><br><p>
 
     <p align="center"><label>Среда программирования:<br></label>
     <input name="sreda" type="text" size="25" maxlength="100"></p>
 
     <p align="center"><label>Тематика::<br></label>
     <input name="tematika" type="text" size="25" maxlength="100"></p>
 
     <p align="center"><label>Укажите год:</label><br>
     <select name="year">
     <option select></p>
     <option value="2013/2014">2013/2014
     <option value="2014/2015">2014/2015
     </select><br><p>
 
     <p align="center"><label>Укажите предмет:</label><br>
     <select name="predmet">
     <option select></p>
     <option value="Информатика">Информатика
     <option value="Методы Оптимизации">Методы Оптимизации
     </select><br><p>
 
    <input type='submit' value='Загрузить на сервер'/>
    </form><br>
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
     <td align="center"><?php       $file_id = 555;// Уникальный идентификатор
      $name = @$_SESSION['login'];
      $poluchatel_file = $array2['id'];// id пользователя, для которого предназначается комментарий
      $mysqli = new mysqli("user", "user", "user", "user", 3306);// Подключается к базе данных
 
      $mysqli->query("SET CHARACTER_SET_client='cp1251'");
      $mysqli->query("SET CHARACTER_SET_results='cp1251'");
      $mysqli->query("SET collation_connection='cp1251_general_ci'");
 
      $result_set = $mysqli->query("SELECT * FROM `files` WHERE `file_id`='$file_id' AND `poluchatel_file` = " .$array2['id']); //Вытаскиваем все данные для данного файла
 
      if($result_set)
       {
        while ($row = $result_set->fetch_assoc())
        {
         print_r($row["tematika"]); echo "<br>"; //Вывод комментариев
        }
       }
 ?></td> <!-- Тематика -->
 
 
     <td align="center"><?php 
 
 
 $filename = 'stats.txt';//файл для хранения
 $array = object_from_file($filename);
 
 if(isset($_POST['sub']) and isset($_POST['stats']) and !empty($_POST['stats']))
 {
    if($array == false)
    {
        $array=array();
    }
    $array[$_POST['file']]= $_POST['stats'];
    object2file($array,$filename);
 } 
 
 $dir = "upload/".$array2["group"]."/".$array2["login"]."/";   
 
 if(is_dir($dir))
 {
    $files = scandir($dir); //сканируем (получаем массив файлов)
    array_shift($files); // удаляем из массива '.'
    array_shift($files); // удаляем из массива '..'
 
    for($i=0; $i<sizeof($files); $i++)
    {
        if($array !== false)
        {
            $s=(array_key_exists($files[$i],$array)==true)?$array[$files[$i]]:'';
        }
            else
            {
                $s = '';
            }
            echo '<a href="'.$dir.$files[$i].'" title="скачать файл"> '.$files[$i].'</a> '.$s.'
            <form method="post" name="">
            Выберите Статус
            <select name="stats">
            <option select></p>
            <option value="Выполнено">Выполнено
            <option value="Не выполнено">Не выполнено
            </select>
            <input type="hidden" name="file" value="'.$files[$i].'">
            <input type="submit" name="sub"> 
            <input type="hidden" name="login" value="<?php echo $_SESSION[login]?>"></form>
            <form action="delete.php" method="post"><button name="path" value="'.$dir.$files[$i].'">Удалить файл</button></form><br>';
    }
 }
?></td>
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.01.2014, 23:10
Ответы с готовыми решениями:

При удалении учащихся из журнала удаляет все связанные записи с ним в остальных таблицах
При удалении учащихся из журнала удаляет все связанные записи с ним в остальных таблицах. В задании написано что это должен быть триггер....

Запуск ПК, а вместе с ним и google chrome вместе с вкладкой akisho
Сначала была стартовая страница time to read, и поиск go search, потом поисковик был майла. После нескольких манипуляций удалось избавиться...

При удалении информации с внешнего ЖД объем свободного пространства не увеличивается
Здравствуйте! У меня такая проблем1а - внешний накопитель (объем 595 ГБ), он у меня заполнен почти весь, но сколько бы я не удалил оттуда...

15
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
05.01.2014, 23:43
http://sitear.ru/material/mysql-primery
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
06.01.2014, 00:14  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
http://sitear.ru/material/mysql-primery
Спасибо конечно, но я знаю что мне нужно делать через DELETE, но не знаю как удалить именно те данные, что пришли с файлом в таблицу.
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
06.01.2014, 00:38
Скиньте в личку ваши файлы
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
06.01.2014, 10:46  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
Скиньте в личку ваши файлы
А зачем?
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
06.01.2014, 11:02
TheRealKos, у вас неправильно организовано удаление.
PHP
1
<button name="path" value="'.$dir.$files[$i].'">Удалить файл</button>
Тут вы передаёте путь на файл, это неправильно. Нужно передавать ID файла в базе, а не путь. Потом делаете так:
- Вытаскиваете информацию о файле по ID, удаляете файл, потом удаляете запись с этим ID.
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
06.01.2014, 11:21  [ТС]
Цитата Сообщение от lyod Посмотреть сообщение
Тут вы передаёте путь на файл, это неправильно. Нужно передавать ID файла в базе, а не путь. Потом делаете так:
- Вытаскиваете информацию о файле по ID, удаляете файл, потом удаляете запись с этим ID.
У меня ID файла не записывается(к сожалению, точнее у всех файлов file_id = 555, а вот ID при новой записи увеличивается на 1). Вот структура таблицы
0
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
06.01.2014, 11:30
Цитата Сообщение от TheRealKos Посмотреть сообщение
а вот ID при новой записи увеличивается на 1
Вот как раз этот ID и используйте, он ведь уникален и по нему можно удалять.

Добавлено через 51 секунду
А вообще, зачем $file_id?
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
06.01.2014, 12:51
TheRealKos, чтобы разобраться и дать вам готовое решение, а не вытягивать из вас все что надо.
Например, вот так можно
PHP
1
2
3
4
echo '<a href="?del="'.$id_файла.'>Удалить</a>';
Ну и дальше
if ($_GET['del'])
mysql_query("delete from table where id=$_GET['del']") or die ('Ошибка удаления');
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
06.01.2014, 16:19  [ТС]
У меня сейчас удалить вот так:
PHP
1
<form action="delete.php" method="post"><button name="path" value="'.$dir.$files[$i].'">Удалить файл</button></form><br>
В delete.php пока что вот так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
  include("blocks/header.php");
  
  if (unlink($_POST['path']))
   { echo "Файл удален<br><a href='index.php'>Назад</a>"; }
  else
   { echo "Ошибка при удалении файла<br><a href='index.php'>Назад</a>"; }
  include("blocks/footer.php");
?>
 
<html>
<head>
<title>Удаление</title>
</head>
</html>
Цитата Сообщение от lyod Посмотреть сообщение
Вот как раз этот ID и используйте, он ведь уникален и по нему можно удалять.
Как бы этот ID передать...

Цитата Сообщение от cellse Посмотреть сообщение
вот так можно
У меня без ссылки сделано, как тут быть?
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
06.01.2014, 16:36
$row['id'] - тут должен быть id вашего файла
а передать его можете, запихнув в скрытый элемент формы
после этого
<form action="delete.php" method="post">
добавим
PHP
1
2
echo '<input type="hidden" name="delete_id" value="'.$row['id'].'">';
echo '<input type="submit" name="delete" value="Удалить">';
в файле delete.php напишем
PHP
1
if($_POST['delete']) echo $_POST['delete_id'];
где $_POST['delete_id'] - id файла, который вы не можете передать

Либо можете в сессию его запихнуть, либо можете делать удаление на этой же странице, да много вариантов.
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
06.01.2014, 17:35  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
PHP
1
echo '<input type="submit" name="delete" value="Удалить">';
Если я это добавлю, то получается же что две кнопки будет: Одна "Удалить", другая "Удалить файл"

Цитата Сообщение от cellse Посмотреть сообщение
$row['id'] - тут должен быть id вашего файла
А как сюда засунуть id файла?
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
06.01.2014, 19:55
Цитата Сообщение от TheRealKos Посмотреть сообщение
Если я это добавлю, то получается же что две кнопки будет: Одна "Удалить", другая "Удалить файл"
А как сюда засунуть id файла?
Значит удаляйте файл там же, где и запись из БД. Что за глупый вопрос. Ну выберете 1 место где у вас будет все разом удаляться.

Вы же делаете запрос к БД, где вам возвращает результат и из этого результата вы берете только поле с комментариями.

Господи, проще написать всё с нуля и дать вам...
Простите, не выдержал.
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
07.01.2014, 11:24  [ТС]
Цитата Сообщение от cellse Посмотреть сообщение
Значит удаляйте файл там же, где и запись из БД. Что за глупый вопрос. Ну выберете 1 место где у вас будет все разом удаляться.
Я и так хочу сделать, чтобы у меня все в одном месте удалялось. Т.е. по кнопке "Удалить файл", кроме самого файла удалилась бы информация, занесенная вместе с ним.
PHP
1
<form action="delete.php" method="post"><button name="path" value="'.$dir.$files[$i].'">Удалить файл</button></form><br>
Здесь наверно нужно input type="hidden" сделать, но как еще id файла не понимаю...В таблице ID он просто с каждым же разом увеличивается и вот как его вытащить...

Добавлено через 10 минут
А столбик FILE_ID не нужный, у всех файлов он равен 555
0
 Аватар для cellse
70 / 68 / 22
Регистрация: 12.08.2013
Сообщений: 297
07.01.2014, 14:18
В таблице id увеличивается когда заносишь новую запись туда. А когда запрашиваешь из таблицы, тебе возвращается конкретный id твоей записи и он свободен для манипуляций. Чуть позже пришлю вам как сделать удаление это сразу, если другие не напишут

Добавлено через 2 часа 33 минуты
Давайте так сделаем. Скиньте мне ваши файлы, я вам исправлю там всё и пришлю обратно с комментариями
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
08.01.2014, 00:22  [ТС]
Может быть кто еще знает решение?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.01.2014, 00:22
Помогаю со студенческими работами здесь

Удалить данные из XML при удалении из ListBox
Здравствуйте, я начинающий программист, вообще-то это моё хобби и вот не задача хотелось бы сделать программу которая работает как база...

Как сделать, чтобы при удалении информации об студенте проверялось, не используется ли его код в других таблицах...
Ребята помогите пж. Как сделать в ADOQuery чтоб при удалении информации об студенте проверялось нет ли кода етого студента в других...

Удалить файл базы с SD карты при удалении приложения
Возможно ли такое ? Файл базы создаю: public DBHelper(Context context) { super(context, &quot;/sdcard/&quot;+DATABASE_NAME,...

Как при удалении элемента из списка, полностью его удалить
Подскажите, как при удалении элемента из списка, полностью его удалять, чтобы не висел в памяти? #define _CRT_SECURE_NO_WARNINGS ...

Ошибка при удалении объектов (Не удается удалить вложенный объект)
Приветствую! При удалении объектов из базы данных возникает исключение: System.InvalidOperationException: Не удается удалить вложенный...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru