Бесплатный вебинар
«как найти любимую работу»
Подарки на 150 000 ₽ за участие
Живой эфир
Записи не будет!
00:00:00:00
дн.ч.мин.сек.

Работа с операцией NOT на типе данных 'bit' в T-SQL

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

Для инвертирования значения типа bit в T-SQL используйте побитовый оператор ~:

SQL
Скопировать код
SELECT * FROM YourTable WHERE ~YourBitColumn = 1; -- отбираем строки, где YourBitColumn равен 0 или NULL

Если требуется отобрать записи со значением false, примените следующую конструкцию:

SQL
Скопировать код
SELECT * FROM YourTable WHERE YourBitColumn = 0; -- оставляем только те, где значение 0

При необходимости найти значение 0 или NULL, используйте данное выражение:

SQL
Скопировать код
SELECT * FROM YourTable WHERE YourBitColumn = 0 OR YourBitColumn IS NULL; -- выбираем все строки, где значение 0 или NULL
Кинга Идем в IT: пошаговый план для смены профессии

Отработка логического отрицания

Если вам требуется отрицание для типа данных bit, вам поможет оператор ~:

SQL
Скопировать код
DECLARE @MyBit bit = 1; -- Устанавливаем значение TRUE
SELECT ~@MyBit; -- Наступает FALSE. Возвращает 0.

Преимущества использования '~'

Вы вправе прибегнуть к вычитанию:

SQL
Скопировать код
SELECT 1 – @MyBit FROM YourTable; -- используем математическую операцию

Но оператор ~ выглядит проще и более понятно:

SQL
Скопировать код
SELECT ~@MyBit FROM YourTable; -- простое логическое отрицание!

Рекомендации и подводные камни

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Учет NULL

Нельзя не учесть, что NULL останется NULL даже после применения побитового отрицания:

SQL
Скопировать код
DECLARE @MyBit bit = NULL; 
SELECT ~@MyBit; -- NULL продолжает быть NULL. Результат – NULL

Проверки с использованием 'НЕ'

При составлении условий запросов используйте НЕ с явными проверками:

SQL
Скопировать код
-- Подкинем монетку для выбора варианта
SELECT * FROM YourTable WHERE NOT YourBitColumn; -- Отбираем строки, где YourBitColumn не TRUE

-- Готовы к новому раунду? Поехали...
SELECT * FROM YourTable WHERE NOT (YourBitColumn = 1); -- Отбираем строки, где YourBitColumn не 1

Продвинутые операции

Использование в операторе CASE

Применение логического отрицания в условных конструкциях:

SQL
Скопировать код
SELECT CASE WHEN SomeCondition THEN ~YourBitColumn ELSE YourBitColumn END FROM YourTable; -- Для разнообразия результатов...

Применение в JOIN

Побитовое НЕ может улучшить связывание таблиц:

SQL
Скопировать код
SELECT a.*, b.*
FROM TableA a
JOIN TableB b ON a.ID = b.ID AND ~a.YourBitColumn = b.YourBitColumn; -- Присоединяйтесь, добьемся большего эффекта от наших запросов!

Индексы и отрицания

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

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

Представьте себе выключатель света 🎚️: ON 1️⃣ соответствует TRUE, OFF 0️⃣ – FALSE. Оператор НЕ в этом контексте — это действие, меняющее состояние выключателя:

Markdown
Скопировать код
Исходное состояние: 🎚️=1️⃣ (TRUE)

Применяется `НЕ`: 💥🎚️

Финальное состояние: 🎚️=0️⃣ (FALSE)

Простыми словами, оператор НЕ заменяет текущее состояние на противоположное, как если бы вы переключили выключатель света.

Markdown
Скопировать код
Применение `НЕ` к `bit`:

| Исходное состояние | Применено `НЕ` | Финальное состояние |
|------------|----------------|-----------|
| 1️⃣ (TRUE)   | 💥🎚️            | 0️⃣ (FALSE)|
| 0️⃣ (FALSE)  | 💥🎚️            | 1️⃣ (TRUE) |

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

  1. bit (Transact-SQL) – SQL Server | Microsoft Learn — детальное описание типа данных bit и его обработки в T-SQL.
  2. Введение в оконные функции T-SQL – Simple Talk — углубленное изложение материала по T-SQL, включаяб между прочим, изложение работы с логическими операторами.
  3. Побитовые операторы в SQL Server — практическое руководство по работе с побитовыми операторами, включая оператор НЕ, в SQL Server.
  4. SQL Server Programming Best Practices — лучшие практики программирования в SQL Server для предотвращения потери данных и увеличения эффективности кода.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой побитовый оператор используется для инвертирования значения типа 'bit' в T-SQL?
1 / 5