阿里 SQL 代码编码原则和规范

阿里 SQL 代码编码原则和规范

编码原则

SQL 代码的编码原则如下:

  • 代码功能完善。
  • 代码行清晰、整齐,代码行的整体层次分明、结构化强。
  • 代码编写充分考虑执行速度最优的原则。
  • 代码中需要添加必要的注释,以增强代码的可读性。
  • 规范要求并非强制性约束开发人员的代码编写行为。实际应用中,在不违反常规要求的前提下,允许存在可以理解的偏差。
  • SQL 代码中应用到的所有 SQL 关键字、保留字都需使用全大写或小写,例如 select/SELECT、from/FROM、where/WHERE、and/AND、or/OR、union/UNION、insert/INSERT、delete/DELETE、group/GROUP、having/HAVING 和 count/COUNT 等。不能使用大小写混合的方式,例如 Select 或 seLECT 等方式。
  • 4 个空格为 1 个缩进量,所有的缩进均为 1 个缩进量的整数倍,按照代码层次对齐。
  • 禁止使用select *操作,所有操作必须明确指定列名。
  • 对应的括号要求在同一列的位置上。

SQL 编码规范

SQL 代码的编码规范如下:

  • 代码头部

    代码头部添加主题、功能描述、作者和日期等信息,并预留修改日志及标题栏,以便后续添加修改记录。注意每行不超过 80 个字符,模板如下。

    -- MaxCompute(ODPS) SQL
    --**************************************************************************
    -- ** 所属主题: 交易
    -- ** 功能描述: 交易退款分析
    -- ** 创建者 : 有码
    -- ** 创建日期: 20170616 
    -- ** 修改日志:
    -- ** 修改日期 修改人 修改内容
    -- yyyymmdd name comment 
    -- 20170831 无码 增加对biz_type=1234交易的判断 
    --**************************************************************************
    
  • 字段排列要求

    • SELECT 语句选择的字段按照每行 1 个字段的方式编排。
    • 首个选择的字段与 SELECT 之间隔 1 个缩进量。
    • 换行缩进 2 个缩进量后,添加逗号再输入其它字段名。
    • 2 个字段之间的逗号分隔符紧跟在第 2 个字段的前面。
    • AS 语句应与相应的字段在同一行,多个字段的 AS 建议尽量对齐在同一列上。
  • INSERT 子句排列要求

    INSERT 子句写在同一行,请勿换行。

  • SELECT 子句排列要求

    SELECT 语句中所用到的fromwheregroup byhavingorder byjoinunion等子句,需要遵循如下要求:

    • 换行编写。
    • 与相应的 SELECT 语句左对齐编排。
    • 子句首个单词后添加 2 个缩进量,再编写后续的代码。
    • WHERE 子句下的逻辑判断符andor等,与 WHERE 左对齐编排。
    • 超过 2 个缩进量长度的子句加 1 个空格后,再编写后续代码,例如order bygroup by等。
  • 运算符前后间隔要求

    算术运算符、逻辑运算符前后要保留 1 个空格,并写在同一行(超过每行 80 个字符长度的限制除外)。

  • CASE 语句的编写

    CASE 语句可以用于 SELECT 语句中对字段值进行判断取值的操作。CASE 语句编排的规则如下:

    • WHEN 子语在 CASE 语句的同一行,并缩进 1 个缩进量后开始编写。
    • 每个 WHEN 子句尽量在 1 行内编写,如果语句较长可以换行。
    • CASE 语句必须包含 ELSE 子语,ELSE 子句与 WHEN 子句对齐。
  • 查询嵌套编写规范

    在数据仓库系统 ETL 开发中经常使用子查询嵌套,其编写规范示例如下。

  • 表别名定义约定

    • 一旦在 SELECT 语句中给操作表定义了别名,在整个语句中对此表的引用都必须以别名替代,所以需要给所有的表添加别名。

    • 表别名采用简单字符命名,建议按 a、b、c、d…的顺序进行命名,并避免使用关键字。

    • 多层次的嵌套子查询别名之前要体现层次关系,SQL 语句的别名需要分层命名,从第 1 层次至第 4 层次,分别用 P(Part) 、S(Segment)、 U(Unit) 和 D(Detail)表示。您也可以用 a、b、c、d 来表示第 1 层次到第 4 层次。

      对于同一层次的多个子句,在字母后加 1、2、3、4……区分,并根据情况对表别名添加注释。

  • SQL 注释

    • 每条 SQL 语句均应添加注释说明。
    • 每条 SQL 语句的注释单独成行,并放在语句的前面。
    • 字段注释紧跟在字段后面。
    • 对不易理解的分支条件表达式添加注释。
    • 对重要的计算添加注释,说明其功能。
    • 过长的函数实现,应将其语句按实现的功能分段,添加注释进行说明。
    • 添加常量及变量的注释时,应注释被保存值的含义(必选),合法取值的范围(可选)。

原文链接:https://www.alibabacloud.com/help/zh/doc-detail/137491.htm

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 1 引言 1.1 编写目的 本文档用于规范数据库设计、开发等方面的内容。 1.2 预期读者 本文档的预期读者为...
    画风故事汇阅读 3,891评论 0 64
  • 1 编写目的 本手册是为指导开发人员按照文档中的规范进行MYSQL数据库设计及SQL编码。 2 数据库对象定义规范...
    Graddy阅读 2,314评论 0 74
  • Java代码规范整理 对于一个整体的软件系统而言,既需要宏观上的架构决策,设计与指导原则,也必须重视微观上的代码细...
    亚武de小文阅读 2,743评论 8 47
  • Java代码规范整理 对于一个整体的软件系统而言,既需要宏观上的架构决策,设计与指导原则,也必须重视微观上的代码细...
    jeffrey_hjf阅读 5,225评论 0 1
  • 1.命名基本原则 对于理解应用程序的逻辑流,命名方案是最有影响力的一种帮助。名称应该说明“什么”而不是“如何”。命...
    lucas777阅读 170评论 0 0