powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Помогите с запросом!!!
16 сообщений из 16, страница 1 из 1
Помогите с запросом!!!
    #32070222
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Имеем 2 таблички

tab1(id,name), tab2(id,data,org,itog) -
т.е. мастер-деталь по разным предприятиям и датам.
хочется постоить табличку

id,name,itog

для определенных значений (data, org),
НО, чтобы при отсутствии таких данных в tab2 выдавались 0/null, т.е.

select id,name,itog
from tab1 left join tab2 on tab1.id=tab2.id
where data='20.12.2000' and org=5

если нет значений, выдает пусто. А как сделать чтобы не пусто?
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070228
Фотография alexeyvg
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
select id,name,itog
from tab1 left join tab2 on tab1.id=tab2.id and org=5
where data='20.12.2000'
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070232
Фотография mahoune
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plaintext
1.
2.
3.
SELECT a.id, a.name, IF((b.itog=NULL), 0 ,b.itog) as NEW_ITOG
FROM tab1 a LEFT JOIN tab2 b ON tab1.id=tab2.id
WHERE
b.data='20.12.2000' AND b.org= 5 
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070233
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Нет, так не пойдет. Если на эту дату нет ничего? то и получим ничего, а хочется чтобы тогда поле itog было пустое (ну или null)
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070237
Фотография mahoune
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Тады так!
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
SELECT a.id, a.name, IF((b.itog=NULL), 0 ,b.itog) as NEW_ITOG
FROM tab1 a LEFT JOIN tab2 b ON tab1.id=tab2.id
WHERE
(
  b.data='20.12.2000'
  OR
  b.data IS NULL
)
AND
(
  b.org= 5 
  OR
  b.org IS NULL
)
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070238
Зайцев Фёдор
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2mahoune
IF() ????
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070240
Фотография mahoune
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Я SQL тонкостей в Microsoft SQL Server не знаю. А так SQL писать могу :) Как он у Вас там называется IF??? IIF наверное :)
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070247
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Так тоже не так ;-). Потому-как в tab2 НЕТУ значения с data=null. Т.е совсем нету.
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070257
Фотография mahoune
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Так там же OR стоит!
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070259
dmmm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
select id,name,itog
from tab1 left join tab2 on tab1.id=tab2.id
and tab2.data='20.12.2000' and tab2.org=5
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070268
zorro
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
М.б. так

select id, name,
isNull((select itog from tab2 where tab2.ID=tab1.ID
and data='20.12.2000' and org=5 ),0) as itog
from tab1
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070282
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
вот это условие даст false при любом раскладе, если нет записи в таблице:
Код: plaintext
1.
2.
b.data='20.12.2000'
  OR
b.data IS NULL

Что оно и дает - пусто возвращается
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070287
Glory
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2IgorK
Обратите внимание на запрос, предложенный dmmm
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070291
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Пробовал и так - ответ такой-же
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070302
Фотография mahoune
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Приведи пример как результат запроса должен выглядеть и желательно входящие данные тоже, по паре строк!
...
Рейтинг: 0 / 0
Помогите с запросом!!!
    #32070312
IgorK
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
2Glory:
Сори, видимо где-то не так писал! То что надо, спасибо!!!
...
Рейтинг: 0 / 0
16 сообщений из 16, страница 1 из 1
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Помогите с запросом!!!
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]