Различия между Sql существует и в

Anonim

Sql Exists vs In

Решение проблем в TSQL доступно с помощью различных методов, и желаемые результаты можно увидеть, используя любой из них. Одним из способов достижения конечных результатов является использование положений IN и EXISTS. Использование предложений помогает фильтровать результирующий набор со ссылкой на доступный подзапрос. Выполнение IN и EXISTS немного отличается, и эти различия оцениваются.

Существуют различные факторы, определяющие, будут ли выполняться IN или EXISTS. Одним из них является количество данных, доступных в таблице. Огромный объем данных приводит к тому, что SQL-сервер возвращается к использованию сканирования индекса, а не использует индексный поиск.

Различия

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

EXISTS запускаются, когда необходимо сопоставить результаты запроса с другим подзапросом. IN, с другой стороны, используется при извлечении значений конкретных столбцов, которые лежат в списке. Решение о том, что использовать, основано исключительно на уместности, т. Е. Когда вы считаете, что его использование уместно.

В случае, когда используется подзапрос и возвращается значение null, весь оператор становится NULL. Это фактически указывает на использование ключевого слова EXISTS. Использование ключевого слова IN происходит, когда требуется сравнение различных значений в подзапросах. Ключевое слово EXISTS в основном используется при оценке истинных или ложных инструкций, а IN используется в большинстве соответствующих подзапросов.

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

Важно отметить, что формулировка запроса должна быть выполнена правильно и проверяться перед запуском. Невыполнение запроса корректно приводит к тому, что EXISTS и IN представляют разные значения, и это не является целью их использования на SQL-сервере. Оптимизатор всегда должен быть оптимальным при работе.

Резюме

Решение проблем в TSQL обычно выполняется с помощью EXISTS и IN.

Небольшие различия наблюдаются при развертывании EXISTS и IN, хотя оптимизация для каждого должна давать одинаковое значение.

Статистика является одним из факторов, определяющих, будут ли выполняться EXISTS или IN

Используемое оборудование также имеет решающее значение при определении того, следует ли развертывать EXISTS или IN

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

IN обычно используется, когда требуется получить определенные столбцы в списке. Также он обычно используется, когда требуется сравнение значений в подзапросах.

EXISTS, как правило, быстрее, чем IN, когда он запускается, находит удар и проверяет, действительно ли условие подтвердилось

IN медленнее, поскольку он собирает все результаты из подзапроса и обрабатывает его.

Хотя существуют разные исполнения, оптимизация должна давать аналогичные результаты в EXISTS и IN.