72 похожих чатов

Mssql 2014 - Подскажите, почему так работает: SELECT * FROM [Egorka_TorgSoftDB].[dbo].[GoodType]

AS T1
WHERE NOT EXISTS (SELECT GoodTypeID FROM [Egorka_TorgSoftDB].[dbo].[GoodType] AS T2 WHERE T2.GoodTypeID = T1.ID) , а так нет: SELECT *
FROM [Egorka_TorgSoftDB].[dbo].[GoodType]
WHERE ID NOT IN (SELECT GoodTypeID FROM [Egorka_TorgSoftDB].[dbo].[GoodType]) ? При том что если из обеих запросов убрать NOT - они отработают одинаково правильно.

5 ответов

7 просмотров

Скорее всего в значениях есть NULL. IN обрабатывает трехзначную логику: 1 IN (2, null) --> FALSE, т.к. 1 = 2 --> false 1 = null --> unknown false OR unknown --> unknown (!= true) 1 NOT IN (2, null) --> FALSE, т.к. not(1 = 2) --> true not(1 = null) --> not(unknown) --> unknown true AND unknown --> unknown ( != true) NOT IN сработает как ожидаете, если например null значения обернуть в NVL(ID, -1). Или left outer join с условием is null Подробнее: http://www.dbatodba.com/sql-server/how-tos/typical-solutions-to-avoid-using-not-in-on-sql-server/ https://weblogs.sqlteam.com/mladenp/2007/05/18/60210/

Morgan-Ziegler Автор вопроса

Потому что ты не умеешь писать запросы

В подзапросах есть null'ы?

Похожие вопросы

Обсуждают сегодня

А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Всем привет. Нужна платная консультация от тех, кто сталкивался с октябрём в кластере или шарит оч хорошо в цмс. Проблема следующая: после переноса в кластер октябрь начал ...
wl
8
Коллеги, доброе утро. Запустил на удаленном хосте приложение (ручками зашел туда по ssh и запустил, не командой удаленно). Создал потом ssh-туннель, и с моей машины приложение...
Δημήτηρ
9
Добрый день, не подскажите, если в OC-V3 поменять страндартную директорию /storage/ на /storage2/ - не будет сильно много проблем ?
Max Dubovsky
32
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
а я честно сказать не понимаю - нахуя идти учиться на вышку или еще куда-либо и при этом нихуя не делать, типа зачем ? просто корку получить, а нахуй она нужна тогда ?
Eugene Неелов
7
Which companies do you think are innovating best in web design and design practices?
✌️(´ヮ`)
6
> Примечательно, что новый владелец удаляет из GitHub любые жалобы, указывающие на подозрительную активность или смену владельца, и, видимо, рассчитывает на то, что пользовате...
Alex Sherbakov
2
Каким то образом можно определить ширину экрана пользователя перед загрузкой partial-а? Надо рассчитать ширину кадров слайдера для ресайза картинок для container-fluid.
Point 111
22
я часов 15 назад начал пытаться написать хоть что-то напоминающее ос и у меня есть проблема, которую я пытаюсь решить последние часов 5: есть крч 2 исходника с минимальным код...
Al1to
17
Карта сайта