1,不允许使用select *
应该采用列裁剪的方式展示具体字段
2,除数可能为0,没有校验
可以先使用case when 判断一下
3,同名人员取最大工号,不合理
应该深入理解业务,根据实际逻辑获取工号。
4,可以合并优化一下,减少重复访问表
5,一段sql理论上不能同时存在两个相同的表
表要进行合并,过滤条件要累加(把数据都过滤出来),数据展示需要采用case when
6,t1不需要子查询;t1, t2可以通过min( case when ) over (partition by t1.cust_no 的方式,减少自连接
7,过滤条件太多,可以套用子查询,然后再取关联;关联条件尽量简单,不要一边处理一边关联
8,t1表cust_no(主键)数据唯一,但是t2表数据group by之后依旧会有一个cust_no对应多条数据,从而导致数据发散
直接对t2表的cust_no进行group by
9,where 过滤条件直接放里面,无需再次套子查询
10,不允许使用select *
11,t1与t2, group by 之后的结果一样,可以共用一张表
12,一个子查询即可!不允许多套子查询
今天就分享这一小部分再项目代码评审中的问题,属于基础错误,基础优化。
欢迎一键三连!!!