ПРИХОДИТЕ УЧИТЬСЯ НОВОЙ ПРОФЕССИИ ЛЕТОМ СО СКИДКОЙ ДО 70%Забронировать скидку

Исключение альбомов по названию в MySQL с NOT IN

Пройдите тест, узнайте какой профессии подходите и получите бесплатную карьерную консультацию
В конце подарим скидку до 55% на обучение
Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

В MySQL, когда вы хотите исключить определенные записи из выборки, используйте оператор NOT IN:

SQL
Скопировать код
SELECT * FROM your_table WHERE name NOT IN ('Alice', 'Bob', 'Charlie');

Этот SQL-запрос вернёт все строки таблицы, для которых поле name отличается от перечисленных значений.

Пройдите тест и узнайте подходит ли вам сфера IT
Пройти тест

Динамическое формирование списка для NOT IN

Если вам требуется работа с массивом значений при использовании NOT IN, удобно в PHP применять функцию implode(), которая преобразует массив в строку с перечислением значений через запятую.

php
Скопировать код
$unwantedNames = ['Wall', 'Profile', 'Cover', 'Instagram'];
// Формируем список нежелательных имен
$unwantedNamesList = "'" . implode("', '", $unwantedNames) . "'";

Сформированный таким образом список значений можно встраивать в SQL-запрос:

SQL
Скопировать код
$sql = "SELECT * FROM albums WHERE name NOT IN ($unwantedNamesList)";

Предотвращение SQL-инъекций: безопасность на первом месте

Для предотвращения SQL-инъекций используйте подготовленные выражения:

php
Скопировать код
$stmt = $conn->prepare("SELECT * FROM albums WHERE name NOT IN (?)");
$stmt->bind_param("s", $unwantedNamesList);
$stmt->execute();

Не забудьте проверять и валидировать входные данные перед их использованием в SQL-запросах.

Важность тестирования SQL-запросов

После добавления оператора NOT IN обязательно проводите тестирование SQL-запроса, чтобы удостовериться в его корректности и в том, что из результатов исключены указанные значения.

Визуализация

Посмотрим на простом примере, как работает NOT IN:

Исходные данные (table): [Alice, Bob, Charlie, Dave] Массив значений для исключения (name array): [Bob, Dave]

В результате выполнения запроса с NOT IN:

SQL
Скопировать код
SELECT name FROM table WHERE name NOT IN ('Bob', 'Dave');

Мы получим следующие изменения:

До: [👩 Alice, 👨 Bob, 👦 Charlie, 👨 Dave] После: [👩 Alice, 👦 Charlie]

Таким образом, в списке остаются только Alice и Charlie.

Поддержание данных в чистоте

Обеспечение корректности данных

Убедитесь, что ваш массив данных содержит только элементы ожидаемого типа данных. Для этого используйте функции фильтрации PHP:

php
Скопировать код
array_filter($inputArray, 'is_string');

Защита от инъекций на профессиональном уровне

Примените параметризованные запросы для разделения данных от SQL-кода, что повышает безопасность: это позволяет предотвратить SQL-инъекции.

Настройка с помощью альтернативных методов

Изучение возможностей JOIN

В определённых случаях использование UNION или JOIN может стать эффективной альтернативой NOT IN для выполнения более сложных операций по исключению данных.

EXISTS против IN: дорога к оптимизации

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

Полезные материалы

  1. NOT IN vs NOT EXISTS – Stack Overflow — Детальное обсуждение преимуществ и тонкостей оптимизации при использовании NOT IN и NOT EXISTS.
  2. Советы по повышению производительности SQL JOIN — Коллекция советов по повышению эффективности разных типов операций объединения (JOIN) в SQL.
  3. Рекомендации по ускорению SQL-подзапросов – SQL Shack — Руководство по повышению производительности SQL-подзапросов. Работа с подзапросами и NOT IN могут отлично дополнять друг друга.