Где (SQL) - Википедия - Where (SQL)
Эта статья нужны дополнительные цитаты для проверка.Сентябрь 2014 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
А КУДА
пункт в SQL указывает, что SQL Язык манипулирования данными (DML) заявление должно затрагивать только ряды которые соответствуют указанным критериям. Критерии выражаются в форме предикатов. КУДА
предложения не являются обязательными предложениями операторов SQL DML, но могут использоваться для ограничения количества строк, затронутых оператором SQL DML или возвращаемых запросом. Вкратце предложение SQL WHERE используется для извлечения только тех результатов из оператора SQL, как: SELECT, INSERT, UPDATE или DELETE.[1]
Обзор
КУДА
является SQL зарезервированное слово.
В КУДА
Предложение используется вместе с операторами SQL DML и принимает следующую общую форму:
SQL-DML-ЗаявлениеИЗ table_name КУДА предикат
все строки, для которых предикат в КУДА
предложение равно True, на них влияет (или возвращается) инструкция или запрос SQL DML. Строки, для которых предикат оценивается как False или Unknown (НОЛЬ ) не зависят от оператора или запроса DML.
Следующий запрос возвращает только те строки из таблицы mytable где значение в столбец Mycol больше 100.
ВЫБРАТЬ *ИЗ mytableКУДА Mycol > 100
Следующее УДАЛИТЬ
утверждение удаляет только эти строки из таблицы mytable где столбец Mycol либо NULL, либо имеет значение, равное 100.
УДАЛИТЬИЗ mytableКУДА Mycol ЯВЛЯЕТСЯ НОЛЬ ИЛИ ЖЕ Mycol = 100
Предикаты
Простые предикаты используют один из операторов =
, <>
, >
, >=
, <
, <=
, В
, МЕЖДУ
, ПОДОБНО
, НУЛЕВОЙ
или же НЕ ПУСТО
.
При желании предикаты можно заключить в круглые скобки. Ключевые слова И
и ИЛИ ЖЕ
может использоваться для объединения двух предикатов в новый. Если применяется несколько комбинаций, можно использовать круглые скобки для группировки комбинаций, чтобы указать порядок оценки. Без круглых скобок И
оператор имеет более сильную привязку, чем ИЛИ ЖЕ
.
В следующем примере удаляются строки из mytable где значение Mycol больше 100, и значение элемент равно строковый литерал 'Молоток':
УДАЛИТЬИЗ mytableКУДА Mycol > 100 И элемент = 'Молоток'
В
В
найдет любые значения, существующие в наборе кандидатов.
ВЫБРАТЬ эмаль КУДА эмаль В ('Монреаль', 'Квебек')
Все строки соответствуют предикату, если их значение является одним из возможных наборов значений. Это то же поведение, что и
ВЫБРАТЬ эмаль КУДА эмаль='значение1' ИЛИ ЖЕ эмаль='значение2'
за исключением того, что последний может позволять сравнивать несколько столбцов, каждый из которых В
пункт не делает. Для большего количества кандидатов В
менее подробный.
МЕЖДУ
МЕЖДУ
найдет любые значения в пределах диапазона.
ВЫБРАТЬ эмаль КУДА эмаль МЕЖДУ 'значение1' И 'значение2'
ВЫБРАТЬ зарплата из emp КУДА зарплата МЕЖДУ 5000 И 10000
Все строки соответствуют предикату, если их значение находится в диапазоне от «значение1» до «значение2» включительно.
ПОДОБНО
ПОДОБНО
найдет строку, соответствующую определенному описанию.
- Конец Подстановочный знак
- Найдите любую строку, которая начинается с буквы "S"
ВЫБРАТЬ эмаль ИЗ emp КУДА эмаль ПОДОБНО 'S%';
- Найдите любую строку, которая начинается с буквы "S"
- Ведущий подстановочный знак
- Найдите любую строку, которая заканчивается на букву "S"
ВЫБРАТЬ эмаль ИЗ emp КУДА эмаль ПОДОБНО '% S';
- Найдите любую строку, которая заканчивается на букву "S"
- Множественные подстановочные знаки
- Найдите любую строку, содержащую в любом месте букву "S"
ВЫБРАТЬ эмаль ИЗ emp КУДА эмаль ПОДОБНО '% S%';
- Найдите любую строку, содержащую в любом месте букву "S"
- Подстановочный знак из одного символа
- Найдите любую строку, содержащую букву «А», за которой следует любой отдельный символ, за которым следует буква «Е».
ВЫБРАТЬ эмаль ИЗ emp КУДА эмаль ПОДОБНО '% A_E%';
- Найдите любую строку, содержащую букву «А», за которой следует любой отдельный символ, за которым следует буква «Е».
- Классы персонажей[2]
- Найдите любую строку, которая начинается с буквы, цифры или символа '_'
ВЫБРАТЬ эмаль ИЗ emp КУДА эмаль ПОДОБНО '[a-zA-Z0-9 _]%';
- Найдите любую строку, которая начинается с буквы, цифры или символа '_'
Программисты SQL должны знать, что предикат LIKE обычно выполняет поиск без обычного повышения производительности индексов. Использование '=', '<>' и т. Д. Вместо этого повысит производительность. Пользователи предиката LIKE должны знать, что чувствительность к регистру (например, «S» по сравнению с «s») может быть разной в зависимости от продукта или конфигурации базы данных.
Рекомендации
- ^ "Предложение SQL WHERE - вещи, которые должны знать новички".
- ^ Microsoft Technet Проверено 21 ноября 2013 года.
внешняя ссылка
- PSOUG Home Группа пользователей Puget Sound Oracle дает несколько примеров операторов SELECT с предложениями WHERE.