运算符 参考
基本运算符:
1、=表示 等于;
2、<> 表示不等于;(注释:在 SQL 的一些版本中,该操作符可被写成 !=);
3、> 表示大于;
4、< 表示小于;
5、>= 表示大于等于;
6、<= 表示小于等于
7、<=>安全等于,除等号作用外,还可以比较null值;也就是null <=> null 返回1;
Group by 和分组函数用法
- 参考1
- 参考2
- 获取每个部门中当前员工薪水最高的相关信息:
# 误区:使用GROUP BY子句后,select 语句中只能出现group by语句中出现的字段,或者聚合函数, # 所以这里无法同时出现dept_no,emp_no. SELECT d.dept_no, d.emp_no, s.salary FROM dept_emp d INNER JOIN salaries s ON d.emp_no = s.emp_no WHERE (d.dept_no, s.salary) IN( select d.dept_no, max(s.salary) from dept_emp d inner join salaries s on d.emp_no = s.emp_no group by d.dept_no ) ORDER by d.dept_no;
Limit Offset 用法
- LIMIT n: 表示从第1条开始,取n条数据,是limit 0,n 的缩写。
- LIMIT m,n: 表示从第m+1条开始,取n条数据;
- LIMIT m OFFSET n: 表示从n+1条开始,取m条数据;
外连接和内连接
- 内连接:两边表同时有对应的数据,即任何一边缺失数据就不显示;
- 外连接: 读取左边数据表(主表)的全部数据,即便右边表(从表)无对应数据,如果从表和它匹配的将显示匹配行,如果从表没有匹配的则用null填充;
执行顺序 参考
- 从from开始执行,分组筛选后,去重,排序,分页,结束。
⑦SELECT
⑧DISTINCT <select_list>
①FROM <left table>
②<join_type> JOIN <right_talbe>
③ON <join_condition>
④WHERE <where_condition>
⑤GROUP BY <group_by_list>
⑥HAVING <having_condition>
⑨ORDER BY <order_by_condition>
⑩LIMIT <limit_number>