В этой лекции мы рассмотрим, как выбрать данные на основе условий SQL, представленных с помощьюбулевых (логических) операторов.
AND
OR
NOT
Использовать их очень просто. Ниже показан оператор SELECT, который выводит имена сотрудников, которые получают более 70000, но меньше 90000.
SELECT f_name, l_name from employee_datawhere salary > 70000 AND salary < 90000;
На рис. 6.1. приведен результат запроса.
Рис. 6.1. Имена сотрудников, которые получают более 70000, но меньше 90000
Давайте выведем список сотрудников, фамилии которых начинаются с буквы К или Л.
SELECT l_name from employee_data wherel_name like 'К%' OR l_name like 'Л%';
На рис. 6.2. приведен результат запроса.
Рис. 6.2. Сотрудники, фамилии которых начинаются с буквы К или Л
Вот более сложный пример ... список имен и возраста сотрудников, фамилии которых начинаются с К или Л, и которые младше 30 лет.
SELECT f_name, l_name , age from employee_datawhere (l_name like 'К%' OR l_name like 'Л%') AND age < 30;
На рис. 6.3. приведен результат запроса.
Рис. 6.3. Список имен и возраста сотрудников, фамилии которых начинаются с К или Л, и которые младше 30 лет
Обратите внимание на использование скобок в представленном выше операторе. Скобки предназначены для выделения различных логических условий и удаления двусмысленностей.
Оператор NOT поможет при поиске всех сотрудников, которые не являются программистами. (Программисты включают старших программистов, программистов мультимедиа и программистов).
SELECT f_name, l_name, title from employee_datawhere title NOT LIKE "%программист%";
На рис. 6.4. приведен результат запроса.
Рис. 6.4. Поиск всех сотрудников, которые не являются программистами
И последний пример перед упражнениями.
Показать всех сотрудников со стажем работы в компании более 3 лет, которые старше 30 лет.
select f_name, l_name from employee_datawhere yos > 3 AND age > 30;
На рис. 6.5. приведен результат запроса.
Рис. 6.5. Все сотрудники, которые старше 30 лет, и имеют стаж работы более 3 лет