Ищет элегантный способ обойти это ...SQL и ALL оператор
DECLARE @ZIP INT
SET @ZIP = 55555
IF @ZIP = ALL(SELECT ZIP FROM PEOPLE WHERE PERSONTYPE = 1)
PRINT 'All people of type 1 have the same zip!'
ELSE
PRINT 'Not All people of type 1 have the same zip!'
Вопрос заключается в том, что, если (SELECT ZIP FROM НАРОДА WHERE PERSONTYPE = 1) не возвращает никаких записей, то выше IF Равняется к истине. Я ищу способ сделать это оценивать как false, когда нет записей, возвращаемых подзапросом ALL.
Мое текущее решение:
DECLARE @ZIP INT
SET @ZIP = 55555
DECLARE @ALLZIPS TABLE (INT ZIP)
INSERT INTO @ALLZIPS
SELECT ZIP FROM PEOPLE WHERE PERSONTYPE = 1
IF EXISTS(SELECT TOP 1 * FROM @ALLZIPS) AND (@ZIP = ALL (SELECT ZIP FROM @ALLZIPS))
PRINT 'All people of type 1 have the same zip!'
ELSE
PRINT 'Not All people of type 1 have the same zip!'
MS SQL Server (T-SQL стандарт) – MooseCoder