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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 26.08.2008, 17:50
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию SQL запрос

Необходимо сделать запрос в 10 таблиц базы данных ACCESS. Дело в том, что длина строки запроса получается слишком велика, можно ли как-то упростить запрос? Для объединения запросов использую UNION.

Пример запроса в 2 таблицы, а надо в 10:

Код:
ADOQuery1.SQL.add('SELECT * FROM LIST1 where Availability = "ASAP" UNION SELECT * FROM LIST2 where Availability = "ASAP"');
Ответить с цитированием
  #2  
Старый 27.08.2008, 08:35
Аватар для Appolon
Appolon Appolon вне форума
Новичок
 
Регистрация: 10.01.2008
Адрес: гЕйск
Сообщения: 76
Репутация: 16
По умолчанию

Может вот так вот:
Код:
with ADOQuery1.SQL do begin
  Add('SELECT * FROM LIST1 where Availability = "ASAP"');
  Add(' UNION ');
  Add('SELECT * FROM LIST2 where Availability = "ASAP"');
  Add(' UNION ');
  Add('SELECT * FROM LIST3 where Availability = "ASAP"');
  и т.д.
end;
__________________
From VasYa with LoVe...
Ответить с цитированием
  #3  
Старый 27.08.2008, 10:49
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию

Как раз то, что нужно, спасибо!
Ответить с цитированием
  #4  
Старый 27.08.2008, 17:36
xchrom xchrom вне форума
Начинающий
 
Регистрация: 08.04.2008
Сообщения: 177
Репутация: 15
По умолчанию

ну не понимаю я!
а почему нельзя просто сделать
Код:
select * from list1,list2,list3,list4
where Availability = "ASAP"
???
Ответить с цитированием
  #5  
Старый 27.08.2008, 17:38
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию

Цитата:
Сообщение от xchrom
ну не понимаю я!
а почему нельзя просто сделать
Код:
select * from list1,list2,list3,list4
where Availability = "ASAP"
???

Так пробовал изначально. Почему-то выдает ошибку
Ответить с цитированием
  #6  
Старый 27.08.2008, 18:09
xchrom xchrom вне форума
Начинающий
 
Регистрация: 08.04.2008
Сообщения: 177
Репутация: 15
По умолчанию

упс, точно поспешил ))) не получается так
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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