SQL-соединение по дополнительному столбцу на основе условия - PullRequest
1 голос
/ 11 сентября 2011

Я хочу знать, как добавить дополнительный столбец в объединение на основе условия.

Я пытаюсь сделать что-то вроде плана ниже. Если местоположение округа, то я хочу, чтобы все свойства в округе; однако, если местоположение - город, я хочу свойства в этом городе. К сожалению, коды городов могут дублироваться по округам, поэтому мне нужно отфильтровать по кодам округов и городов.

SELECT DISTINCT [PropertyID] 
FROM PropertyLocations
LEFT JOIN [dbo].[Locations]
   ON [PropertyLocations].[CountyCode] = [Locations].[CountyCode]
 -- IF / CASE locations.[LocationLevel] is 6 then 
 -- i want to join on a second column as well
 -- [PropertyLocations].[CountySubCode] = [Locations].[SubCountyCode]
WHERE [LocationName] = 'county/town name'
AND [PropertyLocations].[CountyCode] = [Locations].[CountyCode]
order BY [PropertyID]

1 Ответ

4 голосов
/ 11 сентября 2011

Это то, что вам нужно?

   LEFT JOIN [dbo].[Locations]
     ON [PropertyLocations].[CountyCode] = [Locations].[CountyCode]
        AND ( [Locations].[LocationLevel] <> 6
               OR [PropertyLocations].[CountySubCode] =
                  [Locations].[SubCountyCode]
            )
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...