MaxCompute SQL开发基础

简介: 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的热门话题分析
Apsara Clouder大数据专项技能认证配套课程:基于MaxCompute的热门话题分析
目录
相关文章
|
7月前
|
SQL 存储 分布式计算
【万字长文,建议收藏】《高性能ODPS SQL章法》——用古人智慧驾驭大数据战场
本文旨在帮助非专业数据研发但是有高频ODPS使用需求的同学们(如数分、算法、产品等)能够快速上手ODPS查询优化,实现高性能查数看数,避免日常工作中因SQL任务卡壳、失败等情况造成的工作产出delay甚至集群资源稳定性问题。
1399 36
【万字长文,建议收藏】《高性能ODPS SQL章法》——用古人智慧驾驭大数据战场
|
8月前
|
SQL 分布式计算 大数据
SparkSQL 入门指南:小白也能懂的大数据 SQL 处理神器
在大数据处理的领域,SparkSQL 是一种非常强大的工具,它可以让开发人员以 SQL 的方式处理和查询大规模数据集。SparkSQL 集成了 SQL 查询引擎和 Spark 的分布式计算引擎,使得我们可以在分布式环境下执行 SQL 查询,并能利用 Spark 的强大计算能力进行数据分析。
|
10月前
|
SQL 人工智能 分布式计算
别再只会写SQL了!这五个大数据趋势正在悄悄改变行业格局
别再只会写SQL了!这五个大数据趋势正在悄悄改变行业格局
201 0
|
SQL 大数据 数据挖掘
玩转大数据:从零开始掌握SQL查询基础
玩转大数据:从零开始掌握SQL查询基础
425 35
|
12月前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
12月前
|
关系型数据库 MySQL 大数据
大数据新视界--大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)
本文延续前篇,深入探讨 MySQL 数据库 SQL 语句调优进阶策略。包括优化索引使用,介绍多种索引类型及避免索引失效等;调整数据库参数,如缓冲池、连接数和日志参数;还有分区表、垂直拆分等其他优化方法。通过实际案例分析展示调优效果。回顾与数据库课程设计相关文章,强调全面认识 MySQL 数据库重要性。为读者提供综合调优指导,确保数据库高效运行。
|
人工智能 DataWorks 大数据
大数据AI一体化开发再加速:DataWorks 支持GPU类型资源
大数据开发治理平台 DataWorks 的Serverless资源组支持GPU资源类型,以免运维、按需付费、弹性伸缩的Serverless架构,将大数据处理与AI开发能力无缝融合。面向大数据&AI协同开发场景,DataWorks提供了交互式开发和分析工具Notebook。开发者在创建个人开发环境时,可以选择GPU类型的资源作为Notebook运行环境,以支持进行高性能的计算工作。本教程将基于开源多模态大模型Qwen2-VL-2B-Instruct,介绍如何使用 DataWorks Notebook及LLaMA Factory训练框架完成文旅领域大模型的构建。
891 24
|
数据采集 机器学习/深度学习 DataWorks
DataWorks产品评测:大数据开发治理的深度体验
DataWorks产品评测:大数据开发治理的深度体验
569 1
|
SQL 算法 大数据
为什么大数据平台会回归SQL
在大数据领域,尽管非结构化数据占据了大数据平台80%以上的存储空间,结构化数据分析依然是核心任务。SQL因其广泛的应用基础和易于上手的特点成为大数据处理的主要语言,各大厂商纷纷支持SQL以提高市场竞争力。然而,SQL在处理复杂计算时表现出的性能和开发效率低下问题日益凸显,如难以充分利用现代硬件能力、复杂SQL优化困难等。为了解决这些问题,出现了像SPL这样的开源计算引擎,它通过提供更高效的开发体验和计算性能,以及对多种数据源的支持,为大数据处理带来了新的解决方案。