加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

8种常见SQL错误用法

发布时间:2019-06-01 18:55:38 所属栏目:编程 来源:db匠
导读:1、LIMIT 语句 分页查询是最常用的场景之一,但也凡是也是最轻易出题目的处所。好比对付下面简朴的语句,一样平常 DBA 想到的步伐是在 type, name, create_time 字段上加组合索引。这样前提排序都能有用的操作到索引,机能敏捷晋升。 SELECT* FROMoperation WH

可是子查询 a 在我们的SQL语句中呈现了多次。这种写法不只存在特另外开销,还使得整个语句显的繁杂。行使 WITH 语句再次重写:

  1. WITH a AS   
  2. (   
  3.          SELECT   resourceid   
  4.          FROM     my_distribute d   
  5.          WHERE    isdelete = 0   
  6.          AND      cusmanagercode = '1234567'   
  7.          ORDER BY salecode limit 20)  
  8. SELECT    a.*,   
  9.           c.allocated   
  10. FROM      a   
  11. LEFT JOIN   
  12.           (   
  13.                    SELECT   resourcesid, sum(ifnull(allocation, 0) * 12345) allocated   
  14.                    FROM     my_resources r,   
  15.                             a   
  16.                    WHERE    r.resourcesid = a.resourcesid   
  17.                    GROUP BY resourcesid) c   
  18. ON        a.resourceid = c.resourcesid 

总结

数据库编译器发生执行打算,抉择着SQL的现实执行方法。可是编译器只是极力处事,全部数据库的编译器都不是精细绝伦的。

上述提到的大都场景,在其余数据库中也存在机能题目。相识数据库编译器的特征,才气避规其坏处,写出高机能的SQL语句。

措施员在计划数据模子以及编写SQL语句时,要把算法的头脑或意识带进来。

编写伟大SQL语句要养成行使 WITH 语句的风俗。简捷且思绪清楚的SQL语句也能减小数据库的承担 。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读