Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 09.05.2015, 01:23
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию запрос SQL на удаление строк

Помогите пожалуйста написать запрос на удаление записей из 2х таблиц со значением полей совпадающих с значением этих же полей выбранной записи 3ей таблицы
Ответить с цитированием
  #2  
Старый 09.05.2015, 09:07
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Если не создан индекс с каскадным удалением, то одним запросом не выйдет. Два последовательных придется выполнить:
Код:
delete Table1
from Table1 inner join Table3 on Table1.ID=Table3.ID

delete Table2
from Table2 inner join Table3 on Table2.ID=Table3.ID
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Brons14 (10.05.2015)
  #3  
Старый 09.05.2015, 12:02
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

Подскажите, а при таком запросе необходимо создавать новую таблицу, или возможно удаление в уже существующих таблицах?
Ответить с цитированием
  #4  
Старый 09.05.2015, 20:12
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Зачем создавать, просто подставьте вместо Table1, Table2, Table3 из примера имена своих таблиц, и вместо ID укажите ключ ваш.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Brons14 (10.05.2015)
  #5  
Старый 10.05.2015, 12:43
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

Так удаляет все записи во второй таблице, использую TADODataSet и не очень разобрался как туда писать запрос SQL вот код:
Код:
with  DataModule2.NaDS do
begin
if Active=True then close;
CommandText:='delete DataModule2.NaDS from DataModule2.NaDS inner join DataModule2.HandDS on DataModule2.NaDS.NaDSID_=DataModule2.HandDS.HandDS_'
Ответить с цитированием
  #6  
Старый 10.05.2015, 16:14
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

sql запрос оперирует именами таблиц, а не псевдонимами. Вместо DataModule2.NaDS вы должны указать исходное имя таблицы. Аналогично и для DataModule2.HandDS
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Этот пользователь сказал Спасибо Страдалецъ за это полезное сообщение:
Brons14 (10.05.2015)
  #7  
Старый 10.05.2015, 16:29
Brons14 Brons14 вне форума
Прохожий
 
Регистрация: 22.04.2012
Сообщения: 40
Репутация: 10
По умолчанию

Спасибо, очень помогли!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 04:48.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter