DataWorks SQL代码编码原则和规范

2023-11-29 15:38

本文主要是介绍DataWorks SQL代码编码原则和规范,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编码原则

SQL代码的编码原则如下:

  • 代码功能完善。
  • 代码行清晰、整齐,代码行的整体层次分明、结构化强。
  • 代码编写充分考虑执行速度最优的原则。
  • 代码中需要添加必要的注释,以增强代码的可读性。
  • 规范要求并非强制性约束开发人员的代码编写行为。实际应用中,在不违反常规要求的前提下,允许存在可以理解的偏差。
  • SQL代码中应用到的所有SQL关键字、保留字都需使用全大写或小写,例如select/SELECTfrom/FROMwhere/WHEREand/ANDor/ORunion/UNIONinsert/INSERTdelete/DELETEgroup/GROUPhaving/HAVINGcount/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语句中所用到的from、where、group by、having、order by、join和union等子句,需要遵循如下要求:

    • 换行编写。

    • 与相应的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语句的注释单独成行,并放在语句的前面。

  • 字段注释紧跟在字段后面。

  • 对不易理解的分支条件表达式添加注释。

  • 对重要的计算添加注释,说明其功能。

  • 过长的函数实现,应将其语句按实现的功能分段,添加注释进行说明。

  • 添加常量及变量的注释时,应注释被保存值的含义(必选),合法取值的范围(可选)。

  • 将鼠标放置对应SQL语句之后,使用Crtl+/或Cmd+/快捷键即可注释当前语句。如果您需要注释多行语句,则可以选中需要注释的语句,使用Crtl+/或Cmd+/批量完成注释。

说明

  • Windows系统仅支持使用Crtl+/快捷键注释SQL语句。
  • Mac系统仅支持使用Cmd+/快捷键注释SQL语句。

这篇关于DataWorks SQL代码编码原则和规范的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/433381

相关文章

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java