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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 01.03.2016, 14:22
Moneo Moneo вне форума
Прохожий
 
Регистрация: 26.02.2016
Сообщения: 8
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию ADOquery запрос между 2 таблицами исключающий повторения

Здравствуйте. Собственно вопрос: как составить запрос между 2 таблицами в АДО, в которых не одинаковая структура, но есть общее поле CATALOG, чтобы в наборе данных выводились все записи по всем полям из 2 таблицы, совпадений по поле каталог, которых нету в 1 таблице.
Ответить с цитированием
  #2  
Старый 01.03.2016, 14:45
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

where not exists (select ...
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #3  
Старый 01.03.2016, 14:54
Moneo Moneo вне форума
Прохожий
 
Регистрация: 26.02.2016
Сообщения: 8
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
where not exists (select ...

Подробнее можно, выражение вида
Код:
form2.adoquery3.SQL.add('SELECT * FROM temporable where not exists (select [catalog] from CB)');
выдает пустой набор днных
Ответить с цитированием
  #4  
Старый 01.03.2016, 15:19
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Код:
SELECT *
  FROM t04
 WHERE NOT EXISTS
          (SELECT 1
             FROM t04m
            WHERE t04m.kod_kab = t04.kod_kab)
общее поле kod_kab
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Этот пользователь сказал Спасибо NumLock за это полезное сообщение:
Moneo (01.03.2016)
  #5  
Старый 01.03.2016, 15:54
Moneo Moneo вне форума
Прохожий
 
Регистрация: 26.02.2016
Сообщения: 8
Версия Delphi: Delphi 10
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
Код:
SELECT *
  FROM t04
 WHERE NOT EXISTS
          (SELECT 1
             FROM t04m
            WHERE t04m.kod_kab = t04.kod_kab)
общее поле kod_kab
Код:
form2.adoquery3.SQL.add('SELECT * FROM temporable where not exists (select 1 from CB where CB.catalog=temporable.catalog)');
неопознанная ошибка, а так
Код:
form2.adoquery3.SQL.add('SELECT * FROM temporable where not exists (select * from CB where CB.[catalog]=temporable.[catalog])');
выводит пустой набор хотя однозначно данные есть

Всё заработало таким вот образом:
Код:
form2.adoquery3.SQL.add('SELECT * FROM temporable where not exists (select 1 from CB where temporable.[catalog]=CB.[catalog])');

Благодарю!

Последний раз редактировалось Moneo, 01.03.2016 в 16:43.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter