转:阿里云dataworks规范
编码原则
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交易的判断 —**
- 字段排列要求
- INSERT子句排列要求INSERT子句写在同一行,请勿换行。
- SELECT子句排列要求SELECT语句中所用到的 from、 where、 group by、 having、 order by、 join和 union等子句,需要遵循如下要求:
- 运算符前后间隔要求算术运算符、逻辑运算符前后要保留1个空格,并写在同一行(超过每行80个字符长度的限制除外)。

- CASE语句的编写CASE语句可以用于SELECT语句中对字段值进行判断取值的操作。CASE语句编排的规则如下:
- 查询嵌套编写规范在数据仓库系统ETL开发中经常使用子查询嵌套,其编写规范示例如下。

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




