某基金大公司大数据项目之代码评审---SQL优化

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,一个子查询即可!不允许多套子查询


今天就分享这一小部分再项目代码评审中的问题,属于基础错误,基础优化。

欢迎一键三连!!!

  • 9
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不被定义喵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值