mysqlサブクエリのケース
1670 ワード
#Zlotkeyと同じ部署の従業員の名前と給与を問い合わせる
#会社の平均より給料が高い従業員の従業員番号、氏名、給料を調べる
#各部門の給与が本部門の平均給与より高い従業員番号、氏名と給与注記を問い合わせる:従業員表と平均給与表を接続してから選別する
#クエリーと名前にアルファベットuを含む従業員同じ部署の従業員の従業員番号と名前まずu従業員を含む部署idをクエリーし、idが同じ場合を調べる
#部門でのクエリーのlocation_id 1700の部門で働く従業員の従業員番号注意先にlocation_を問い合わせるidは1700の部門番号に等しく、従業員番号を照会している
#クエリー管理者はK_ingの従業員の名前と給料、2つのK_がありますing
#最も給料の高い従業員の名前を照会し、firstを要求します.ameとlast_nameは姓という列で表示されます.名前#別名特殊文字は引用符で囲む必要があります
SELECT last_name,salary
FROM employees
WHERE department_id=(
SELECT department_id
FROM employees
WHERE last_name='Zlotkey'
);
#会社の平均より給料が高い従業員の従業員番号、氏名、給料を調べる
SELECT employee_id,last_name,salary
FROM employees
WHERE salary>(
SELECT AVG(salary)
FROM employees
);
#各部門の給与が本部門の平均給与より高い従業員番号、氏名と給与注記を問い合わせる:従業員表と平均給与表を接続してから選別する
SELECT employee_id,last_name,salary
FROM (
SELECT AVG(salary) s,department_id
FROM employees
GROUP BY department_id
) a
INNER JOIN employees e
ON a.department_id=e.department_id
WHERE e.salary>s;
#クエリーと名前にアルファベットuを含む従業員同じ部署の従業員の従業員番号と名前まずu従業員を含む部署idをクエリーし、idが同じ場合を調べる
SELECT employee_id,last_name
FROM employees
WHERE department_id IN(
SELECT DISTINCT department_id
FROM employees
WHERE last_name LIKE '%u%'
);
#部門でのクエリーのlocation_id 1700の部門で働く従業員の従業員番号注意先にlocation_を問い合わせるidは1700の部門番号に等しく、従業員番号を照会している
SELECT employee_id
FROM employees e
WHERE e.`department_id` IN(
SELECT department_id
FROM departments d
WHERE d.`location_id`=1700
)
#クエリー管理者はK_ingの従業員の名前と給料、2つのK_がありますing
SELECT last_name,salary
FROM employees e
WHERE e.manager_id IN(
SELECT `employee_id`
FROM employees m
WHERE `last_name`='K_ing'
);
#最も給料の高い従業員の名前を照会し、firstを要求します.ameとlast_nameは姓という列で表示されます.名前#別名特殊文字は引用符で囲む必要があります
SELECT CONCAT(first_name,last_name) ' . '
FROM employees e
WHERE e.salary=(
SELECT MAX(salary)
FROM employees
);