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

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能