С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
3 / 2 / 1
Регистрация: 13.05.2014
Сообщений: 156

Выборка данных из нескольких таблиц по условиям

06.11.2019, 16:09. Показов 1238. Ответов 3

Студворк — интернет-сервис помощи студентам
Дамы и господа!

Есть несколько таблиц, пускай 2.
В этих таблицах в разных столбцах находятся даты.
ключ - столбец num

Нужно из каждого столбца таблицы выбрать даты в заданном диапазоне дат (т.е. из col1 все даты в диапазоне от 01-01-2019 до 01-07-2019, аналогично из col2 и col3 и tooCol1 и т.п., при этом во всех столбцах есть null значения)

Один из вариантов который я пробовал (соединение делал LEFT OUTER, FULL JOIN и т.п., пробовал использовать UNION получается бред)
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
SELECT
tab.col1, 
tab.col2, 
tab.col3,
tooTab.toocol1,
tooTab.toocol2,
tooTab.toocol3
 
FROM table1 AS tab JOIN
tooTable AS tooTab ON tab.num = tooTab.num
 
WHERE tab.col1 BETWEEN '01-01-2019' AND '01-07-2019' OR
tab.col2 BETWEEN '01-01-2019' AND '01-07-2019' OR
tab.col3 BETWEEN '01-01-2019' AND '01-07-2019' OR
tooTab.toocol1 BETWEEN '01-01-2019' AND '01-07-2019' OR
tooTab.toocol2 BETWEEN '01-01-2019' AND '01-07-2019' OR
tooTab.toocol3 BETWEEN '01-01-2019' AND '01-07-2019'
Результирующая выборка должна иметь следующий вид:
tab.col1 tab.col2 tab.col3 tooTab.toocol1 tooTab.toocol2 tooTab.toocol3
NULL 03.03.2019 null 07.01.2019 01.06.2019 null
10.01.2019 null null 21.05.2019 22.04.2019 18.02.2019

Добавлено через 43 секунды
язык T-SQL
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.11.2019, 16:09
Ответы с готовыми решениями:

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

Выборка данных из нескольких таблиц и с хранимой процедуры
здравствуйте! второй день шарю по форумах, гуглю, а толку нет :wall: у меня есть таблицы Car, Price, Vendor, Model значения нужны из...

Выборка данных из нескольких таблиц. Аналитическая выборка данных
16 Для каждого отдела выбрать отношение зарплаты и комиссионных сотрудников отдела к объему продаж отдела. 17 *Выбрать список штатов в...

3
5954 / 4530 / 1094
Регистрация: 29.08.2013
Сообщений: 28,126
Записей в блоге: 3
06.11.2019, 16:43
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
declare @d1 date
declare @d2 date
set @d1='20190701'
set @d2='20190707'
 
select *
from (select * 
         from table1 tab 
         WHERE tab.col1 BETWEEN @d1 AND @d2 OR tab.col2 BETWEEN @d1 AND @d2 OR tab.col3 BETWEEN @d1 AND @d2 OR) t
left join (select * 
                from tooTable tab 
         WHERE tab.col1 BETWEEN @d1 AND @d2 OR tab.col2 BETWEEN @d1 AND @d2 OR tab.col3 BETWEEN @d1 AND @d2 OR) t1 on t.num = t1.num
0
3 / 2 / 1
Регистрация: 13.05.2014
Сообщений: 156
06.11.2019, 17:48  [ТС]
Спасибо, попробую.
Я тут подумал а CROSS JOIN тут не поможет случаем ли? - понял что не поможет...

Добавлено через 45 минут
Попробовал, но это не тот результат что ожидается.
требуется вообще исключить любые даты кроме тех которые в промежутке '01-01-2019' AND '01-07-2019' из выборки по всем столбцам.
мб, я как-то не правильно перенес код? ибо мне пришлось добавить столбец "num" для выборки не всех полей с таблиц, а заданных и без ошибки...
0
3 / 2 / 1
Регистрация: 13.05.2014
Сообщений: 156
07.11.2019, 07:31  [ТС]
Короче, в моем понимании придется делать временную таблицу или производную таблицу, куда инсертить данные.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.11.2019, 07:31
Помогаю со студенческими работами здесь

Выборка данных из нескольких таблиц
Есть две таблицы. Одна хранит в себе список объектов(поля: object_id,object_name). Вторая - список статусов данных...

Выборка данных SQL Select из нескольких таблиц
loans - таблица кредитных договоров debtors - таблица заемщиков Задача сделать выборку телефонов клиентов по закрытым договорам ...

Поиск данных из нескольких таблиц, по нескольким условиям
Здравствуйте уважаемые форумчане, столкнулся с проблемкой по выбору значения из таблицы... Дело в том, что задается более 2х условий и...

Выборка данных из нескольких таблиц (EF)
Здравствуйте, помогите разобраться в проблеме: Пытаюсь получить данные из базы, пишу запрос public ActionResult Index() { ...

Выборка данных из нескольких таблиц
Добрый день, пишу запрос на выборку из нескольких таблиц, в ходе понял, что одни и теже данные выдаются по нескольку раз, можете помочь в...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru