Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Удаление всех данных из таблицы 
V
    Опции темы
Pavelbej
Дата 23.8.2008, 11:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



Всем привет!

Нужна возможность удаления всех необходимых данных из таблицы (папки и закладки). В процедуре определяестя кто в кого вложен и удаляется. Но почему-то не удаляются все закладки родительской (самой верхней)  папки. Чтобы их удалить нужно несколько раз вызвать процедуру. Такое ощущение что поиск нужных данных не доходит до конца и поэтому и не удаляются. Помогите разобратся:

Код

procedure DeleteAll(idparent: integer);
begin
        with TZQuery.Create(Application) do
        begin
        try
            Connection:= Form1.ZConnection1;
            SQL.Text:= 'SELECT id, type, fk, parent, title FROM moz_bookmarks';
            Open;
            first;
            while not Eof do
            begin

                if fieldbyname('parent').AsInteger=idparent then
                begin

                    if fieldbyname('type').AsInteger=2 then  //это папка
                    begin
                        DeleteAll(FieldbyName('id').AsInteger); //ищем во вложенных папках 
                        delete;// удаляем папку
                    end;

                    if fieldbyname('type').AsInteger=1 then  //это закладка
                    begin
                        if Form1.ZQuery2.Locate('id', FieldbyName('fk').AsInteger, [loCaseInsensitive]) then //адрес закладки находится в другой таблице 
                                  if not (pos('place', Form1.ZQuery2.FieldbyName('url').AsString)=1) then
                                  begin
                                      Form1.ZQuery2.Delete;  //удаляем адрес во второй таблице
                                      delete;// удаляем имя закладки в первой таблице
                                  end;
                    end;                    

                end;
                next;
            end;
        finally
            Free;
        end;
        end;
end;



Это сообщение отредактировал(а) Pavelbej - 23.8.2008, 11:33
PM MAIL   Вверх
Akella
Дата 23.8.2008, 12:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Может я не прав в твоём случае, но удаление в цикле нужно проводить с конца в начало.
PM MAIL   Вверх
Pavelbej
Дата 23.8.2008, 15:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



Цитата(Akella @  23.8.2008,  12:29 Найти цитируемый пост)
Может я не прав в твоём случае, но удаление в цикле нужно проводить с конца в начало. 

А как в таком случае определить вложения?  smile 
PM MAIL   Вверх
Akella
Дата 23.8.2008, 23:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Тебе нужно удалить родителя с детьми? Что за СУБД?
PM MAIL   Вверх
Pavelbej
Дата 23.8.2008, 23:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



Цитата(Akella @  23.8.2008,  23:23 Найти цитируемый пост)
Тебе нужно удалить родителя с детьми? Что за СУБД? 

Родителя трогать нельзя. А вот всех дочерних (папок и закладок) нужно удалить. 
СУБД - SQLite 3

Детали:
places.sqlite - файл закладок Firefox 3, таблица moz_bookmarks
PM MAIL   Вверх
Pavelbej
Дата 25.8.2008, 16:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



Подскажите, что там с удалением в цикле? Что за нюансы?
В приведенном мной коде, папки удаляются все, а вот ссылки никак.  smile 
PM MAIL   Вверх
pseud
Дата 25.8.2008, 18:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Экспёрт Тыдыщ
***


Профиль
Группа: Завсегдатай
Сообщений: 1175
Регистрация: 18.5.2007
Где: Минск, Беларусь

Репутация: 16
Всего: 40



Pavelbej
боюс, у тебя неправильный подход.
как же ты делаешь 
Цитата(Pavelbej @  23.8.2008,  11:31 Найти цитируемый пост)
delete;// удаляем папку

и
Цитата(Pavelbej @  23.8.2008,  11:31 Найти цитируемый пост)
 delete;// удаляем имя закладки в первой таблице

если у тебя открыта выборка куда отобраны и эти записи тоже.

ИМХО тебе надо в таблице завести поле-флаг "к_удалению"
пробегая в своем цикле - этот флаг выставлять.
а потом делать что-то типа:
Код

delete from <table1> where <field1> = 1


Добавлено через 2 минуты и 6 секунд
хотя нет - даже не так
а так ))
пробегая по своей выборке - заполняй массив ID-шников записей.
а по окончании пробега делай
Код

delete from <table1> where <ID> in (<1, 2, ..., n>)



--------------------
Испытание чужого терпения можно считать успешным, если оно лопнуло...
PM MAIL   Вверх
Akella
Дата 27.8.2008, 00:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



ограничение на in  1500 элементов
PM MAIL   Вверх
pseud
Дата 27.8.2008, 09:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Экспёрт Тыдыщ
***


Профиль
Группа: Завсегдатай
Сообщений: 1175
Регистрация: 18.5.2007
Где: Минск, Беларусь

Репутация: 16
Всего: 40



Цитата(Akella @  27.8.2008,  00:23 Найти цитируемый пост)
ограничение на in  1500 элементов

пока не натыкался, но если ето правда - подход немного иной ))

Pavelbej
Код

with TQuery.Create(nil) do
try
  SQL.Add('delete from <table>');
  SQL.Add('where id = :P_ID');
  for i := Low(<array_of_integer>) to High(<array_of_integer>) do
  begin
    Params.ParamByName('P_ID').AsInteger :=  <array_of_integer>[i];
    ExecSQL;
  end;
finally
  Free;
end;




--------------------
Испытание чужого терпения можно считать успешным, если оно лопнуло...
PM MAIL   Вверх
Pavelbej
Дата 28.8.2008, 12:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



pseud, то есть изменить код примерно таким образом: 
Код

type TArray = array of integer;
...
var Arr : TArray;
...

Код

                    if fieldbyname('type').AsInteger=2 then  //это папка
                    begin
                        SetLength(Arr, length(Arr) + 1);
                        Arr[Length(Arr)-1] := FieldbyName('id').AsInteger;
                        DeleteAll(FieldbyName('id').AsInteger, Arr); //ищем во вложенных папках 
                    end;


Не приходилось еще сталкиватся с масивами, да и с базами не все еще понятно.
А что это такое?
Код

:P_ID


PM MAIL   Вверх
pseud
Дата 28.8.2008, 13:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Экспёрт Тыдыщ
***


Профиль
Группа: Завсегдатай
Сообщений: 1175
Регистрация: 18.5.2007
Где: Минск, Беларусь

Репутация: 16
Всего: 40



Дикари! Послушай, я тебя полюбил, я тебя научу. (с) «Кин-дза-дза»

отбросим пока массив и :P_ID (кстати это параметр)
и напишем такой код:
Код

function DeleteNode(ANodeID: Integer): Boolean;
var
  iID: Integer;
  iType: Integer;
begin
  Result := True;
  with TQuery.Create(nil) do
  try
    SQL.Add('SELECT id, type, fk, parent, title FROM moz_bookmarks WHERE parent = ' + IntToStr(ANodeID));
    Active := True;
    First;
    while not Eof do
    begin
      iID := FieldByName('id').AsInteger;
      iType := FieldByName('type').AsInteger;
      if iType = 2 then
        DeleteNode(iID);
      with TQuery.Create(nil) do
      try
        SQL.Add('DELETE FROM moz_bookmarks WHERE id = ' + IntToStr(iID));
        ExecSQL;
      finally
        Free;
      end;
    end;
  finally
    Free;
  end;
end;

он тебе удалит нужный узел со всеми его детьми


--------------------
Испытание чужого терпения можно считать успешным, если оно лопнуло...
PM MAIL   Вверх
Pavelbej
Дата 28.8.2008, 18:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 419
Регистрация: 5.7.2005

Репутация: нет
Всего: 6



pseud, спасибо!  То что нужно smile 
Как все просто оказалось, и даже понял как работает. Жаль что собственных мозгов не хватило самому додуматся.
Еще раз благодарю. smile 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.1279 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.