MaxCompute SQL开发基础

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: MaxCompute SQL开发

SQL基础知识

MaxCompute没有事务概念、主键、索引,不支持update和delete操作

MaxCompute SQL是什么?

MaxCompute SQL是个数据处理工具
Query解析后,计算和存储交由底层的飞天实现
MaxCompute SQL采用的类似于SQL的语法,可以看作是标准SQL的子集,但不能因此简单地把MaxCompute等价成一个数据库
MaxCompute SQL每个作业的准备,提交阶段要话费较长时间,实时性不高。
目前MaxCompute SQL长度有限制,单条不超过2M。

MaxCompute中的数据组织

Project项目空间:

MaxCompute的所有对象都隶属于项目空间
项目时maxcompute计量计费及安全控制的基本单元

Table表:

所有的数据都存储在表里
支持表分区,支持依赖于表的视图

Partition分区:

上传时,手工创建分区并保证质量,需指定分区。
使用insert数据时支持动态分区

MaxCompute SQL的约束

不支持事务
不支持主/外键
不支持索引
不支持Update/Delete

MaxCompute SQL的适用场景

MaxCompute SQL适用于海量数据(GB、TB、EB级别),离线批量计算的场合。
不适合直接对接需要每秒处理几千至数万笔事物的前台业务系统,因为不支持事物,响应时间会比较长
Maxcompute SQL的每个作业的准备,提交等阶段都要花费较长时间,因此实时性不高。

MaxCompute SQL的关键字

MaxCompute将SQL语句的关键字作为保留字。在对表、列或是分区命名时如果使用关键字,需给关键字价"符合进行转意,否则会报错。保留字不区分大小写。常见如下:
% & && 等。

MaxCompute SQL的类型转换

显示转换:指用cast将一种数据类型的值转换为另一种类型的值的行为。
隐式转换:是指依据上下文使用环境及类型转换规则自动进行的类型转换。

MaxCompute SQL的运算符

关系:< >
算术:+ -
位:&
逻辑:and or not

SQL Task介绍

MaxCompute SQL作业提交后,形成任务task,执行时形成任务实例instance,其执行过程自动调用Mapreduce。通过logview监控执行过程。

Mapreduce

MapReduce是面向大数据并行处理的计算模型、框架和平台,它隐含了以下三层含义:
1)MapReduce是一个基于集群的高性能并行计算平台。它允许用市场上普通的商用服务器构成一个包含数十、数百至数千个节点的分布和并行计算集群。
2)MapReduce是一个并行计算与运行软件框架。它提供了一个庞大但设计精良的并行计算软件框架,能自动完成计算任务的并行化处理,自动划分计算数据和计算任务,在集群节点上自动分配和执行任务以及收集计算结果,将数据分布存储、数据通信、容错处理等并行计算涉及到的很多系统底层的复杂细节交由系统负责处理,大大减少了软件开发人员的负担。
3)MapReduce是一个并行程序设计模型与方法。它借助于函数式程序设计语言Lisp的设计思想,提供了一种简便的并行程序设计方法,用Map和Reduce两个函数编程实现基本的并行计算任务,提供了抽象的操作和并行编程接口,以方便地完成大规模数据的编程和计算处理。
MaxCompute SQL的主要功能
1、支持各类运算符
2、通过DDL语句对表、分区以及视图进行管理
3、通过select语句查询表中的记录,通过where语句过滤表中的记录。
4、通过insert语句插入数据、更新数据
5、通过等值连接join操作,支持两张表的关联。支持多张小表的mapjoin。
6、支持通过内置函数和自定义函数来进行计算。
7、支持正则表达式。
正则表达式,又称规则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。

数据定义DDL

CREATE[EXTERNAL] table [IF NOT EXISTS] table_name
[(col_name data_type [COMMENT col_comment],…)]
[COMMENT table_comment]
[PARTITIONED BY (col_name data_type [COMMENT col_comment],…)]
[STORED BY StorageHandler] --仅为外部表
[WITH SERDEPROPERTIES(Options)] --仅限外部表
[LOCATION OSSLocation];--仅限外部表
[LIFECYCLE days] [AS select_statement];
CREATE TABLE [IF NOT EXISTS] table_name LIKE existing_table_name

创建表实例:

快捷建表操作-CTAS

快捷键建表操作-示例:

create table test4 like test3;
--除生命周期属性外,test3的其他属性(字段类型、分区类型)均与test4完全一致。
create table test5 as select * from test2;
--这个操作会创建test5,但分区,生命周期信息不会被拷贝到目标表中。另外操作还会将test2的数据复制到test5中。
添加/删除分区
add/drop

表的其他操作

视图

生命周期

数据操作DML

insert操作-更新表中数据

insert操作-更新动态分区表中的数据

多路输出(MULTIINSERT)

insert操作-values

select操作-查询语法

select操作-where条件

select-其他字句

select操作-子查询几种形式

select-union all

select-join

select操作-semi join半连接

select操作-map join hint

select操作-map join hint说明

select操作-CTE

内置函数Build-in Function

值函数

数据运算函数

字符串处理函数

日期类型处理函数

窗口函数

聚合函数

其他函数

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps&nbsp;
目录
相关文章
|
2月前
|
SQL 关系型数据库 MySQL
【MySQL】根据binlog日志获取回滚sql的一个开发思路
【MySQL】根据binlog日志获取回滚sql的一个开发思路
|
2月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之如何开发ODPS Spark任务
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
13天前
|
SQL 安全 Go
SQL注入不可怕,XSS也不难防!Python Web安全进阶教程,让你安心做开发!
在Web开发中,安全至关重要,尤其要警惕SQL注入和XSS攻击。SQL注入通过在数据库查询中插入恶意代码来窃取或篡改数据,而XSS攻击则通过注入恶意脚本来窃取用户敏感信息。本文将带你深入了解这两种威胁,并提供Python实战技巧,包括使用参数化查询和ORM框架防御SQL注入,以及利用模板引擎自动转义和内容安全策略(CSP)防范XSS攻击。通过掌握这些方法,你将能够更加自信地应对Web安全挑战,确保应用程序的安全性。
43 3
|
1月前
|
SQL JSON 分布式计算
ODPS SQL ——列转行、行转列这回让我玩明白了!
本文详细介绍了在MaxCompute中如何使用TRANS_ARRAY和LATERAL VIEW EXPLODE函数来实现列转行的功能。
|
2月前
|
SQL 分布式计算 MaxCompute
一种基于ODPS SQL的全局字典索引分布式计算思路
本文提供一种能充分利用分布式计算资源来计算全局字典索引的方法,以解决在大数据量下使用上诉方式导致所有数据被分发到单个reducer进行单机排序带来的性能瓶颈。
|
2月前
|
SQL NoSQL 数据库
开发效率与灵活性:SQL vs NoSQL
【8月更文第24天】随着大数据和实时应用的兴起,数据库技术也在不断发展以适应新的需求。传统的SQL(结构化查询语言)数据库因其成熟的数据管理机制而被广泛使用,而NoSQL(Not Only SQL)数据库则以其灵活性和扩展性赢得了众多开发者的青睐。本文将从开发者的视角出发,探讨这两种数据库类型的优缺点,并通过具体的代码示例来说明它们在实际开发中的应用。
50 1
|
2月前
|
SQL 存储 分布式计算
我在淘宝写SQL|ODPS SQL 优化总结
本文结合作者多年的数仓开发经验,结合ODPS平台分享数据仓库中的SQL优化经验。
|
2月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之未保存的ODPS SQL语句该如何找回
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
28天前
|
SQL 分布式计算 大数据
代码编码原则和规范大数据开发
此文档详细规定了SQL代码的编写规范,包括代码的清晰度,执行效率,以及注释的必要性。它强调所有SQL关键字需统一使用大写或小写,并禁止使用select *操作。此外,还规定了代码头部的信息模板,字段排列方式,INSERT, SELECT子句的格式,运算符的使用,CASE语句编写规则,查询嵌套规范,表别名定义,以及SQL注释的添加方法。这些规则有助于提升代码的可读性和可维护性。
15 0
|
28天前
|
SQL 分布式计算 大数据
大数据开发SQL代码编码原则和规范
这段SQL编码原则强调代码的功能完整性、清晰度、执行效率及可读性,通过统一关键词大小写、缩进量以及禁止使用模糊操作如select *等手段提升代码质量。此外,SQL编码规范还详细规定了代码头部信息、字段与子句排列、运算符前后间隔、CASE语句编写、查询嵌套、表别名定义以及SQL注释的具体要求,确保代码的一致性和维护性。
26 0
下一篇
无影云桌面