logo search
Лабы базы Данных / Базы данных / Введение в модель данных SQL

Предикат like

SELECT EMP_NAME, COUNT(*)

FROM EMP, DEPT

WHERE EMP.DEPT_NO = DEPT.DEPT_NO

GROUP BY DEPT.DEPT_NO, EMP_NAME

HAVING COUNT(*) > 1

AND EMP.EMP_NAME LIKE (SELECT EMP1.EMP_NAME

FROM EMP EMP1

WHERE EMP1.EMP_NO = DEPT.DEPT_MNG) || '%';

Пример 15.8. Во всех отделах найти имена и число сотрудников, у которых в данном отделе имеются однофамильцы и фамилии которых начинаются со строки символов, изображающей фамилию руководителя отдела. (html,txt)

Конечно, и в этом случае условие с предикатом LIKE можно переместить из раздела HAVING в раздел WHERE. Этот запрос можно переформулировать в виде, лишенном разделов GROUP BY и HAVING (пример 15.8.1), но вряд ли это разумно, поскольку формулировка является менее понятной и существенно более сложной.

SELECT EMP_NAME, (SELECT COUNT(*)

FROM EMP EMP1

WHERE EMP1.DEPT_NO = EMP.DEPT_NO

AND EMP1.EMP_NAME = EMP.EMP_NAME

AND EMP1.EMP_NO <> EMP.EMP_NO) + 1

FROM EMP

WHERE (SELECT COUNT(*)

FROM EMP EMP1

WHERE EMP1.DEPT_NO = EMP.DEPT_NO

AND EMP1.EMP_NAME = EMP.EMP_NAME

AND EMP1.EMP_NO <> EMP.EMP_NO) > 1

AND EMP_NAME LIKE (SELECT EMP1.EMP_NAME

FROM EMP EMP1, DEPT

WHERE EMP.DEPT_NO = DEPT.DEPT_NO

AND EMP1.EMP_NO = DEPT.DEPT_MNG) || '%';

Пример 15.8.1. (html,txt)