写点什么

将存储过程迁移到 Amazon Redshift(二)

  • 2020-01-02
  • 本文字数:2171 字

    阅读完需:约 7 分钟

将存储过程迁移到 Amazon Redshift(二)

在 Amazon Redshift 中使用存储过程的最佳实践

以下是一些使用存储过程的最佳实践。

确保已在源代码控制工具中捕获了存储过程。

如果您计划将存储过程用作数据处理的关键元素,那么还需建立一套实践,将所有存储过程更改都提交给源代码控制系统。


您还可以考虑定义特定用户(即重要存储过程的拥有者),并实现存储过程创建和修改过程自动化。


您可以使用以下命令检索现有存储过程的源代码:


SHOW procedure_name;

考虑每个存储过程的安全范围和调用者

默认情况下,存储过程运行需要存储过程调用者用户的权限。使用 SECURITY DEFINER 属性可以让存储过程使用其他权限运行。例如,从重要的表中显式撤消对 DELETE 的访问权限,然后定义一个存储过程。该存储过程用于在检查安全列表后执行删除操作。


使用 SECURITY DEFINER 时,请注意以下事项:


  • 请将用于执行存储过程的 EXECUTE 权限授予特定用户,而非授予 PUBLIC。这样可以确保存储过程不会被一般用户误用。

  • 如果可能,请使用架构名称限制存储过程访问的所有数据库对象。例如,使用 myschema.mytable,而非 mytable

  • 请在使用 SET 选项创建存储过程时设置 search_path。这样可以防止其他架构中的同名对象受到重要存储过程的影响。

使用基于集合的逻辑,避免手动循环大型数据集

在存储过程中操作数据时,请尽可能继续使用基于集合的常规 SQL 命令,例如 INSERTUPDATEDELETE


存储过程提供了新的控制结构,例如 FORWHILE 循环。这些控制结构在迭代少量项目(例如表列表)时很有用。但是,应避免使用循环结构替换基于集合的 SQL 操作。例如,通过迭代数百万个值以逐一更新这些值,这种做法低效且缓慢。

注意 REFCURSOR 限制,使用临时表处理较大的结果集

结果集从存储过程返回时,可以作为 REFCURSOR 返回或者使用临时表返回。 REFCURSOR 是内存中的数据结构,在许多情况下它是最简单的选择。


但是,每个存储过程最多只能有一个 REFCURSOR。有时您需要返回多个结果集,或者与多个子过程的结果进行交互,或者返回数百万(或更多)个结果行。在这些情况下,建议您将结果定向到临时表,并返回对临时表的引用作为存储过程的输出。

简化存储过程,对复杂流程进行嵌套处理

请尝试使每个存储过程的逻辑尽可能简单。通过简化,您可以最大限度地提高灵活性,并使存储过程更加易于理解。


当您优化和改进存储过程的代码时,代码可能会变得复杂化。当遇到冗长而复杂的存储过程时,通常可以简化操作,方法是将子元素移到从原始过程调用的单独过程。

使用 AWS Schema Conversion Tool 迁移存储过程

在 Amazon Redshift 宣布支持存储过程后,AWS 还改进了 AWS Schema Conversion Tool,此工具现可将旧数据仓库存储过程转换为 Amazon Redshift 存储过程。


AWS SCT 现已支持将 Microsoft SQL Server 数据仓库存储过程转换为 Amazon Redshift 存储过程。


版本 627 之后,AWS SCT 现在可以将 Microsoft SQL Server 数据仓库存储过程转换为 Amazon Redshift 存储过程。以下是 AWS SCT 中的操作步骤


  1. 新建一个 OLAP 项目,用于将 SQL Server 数据仓库 (DW) 转换到 Amazon Redshift。

  2. 连接 SQL Server DW 和 Amazon Redshift 终端节点。

  3. 取消选中源树中的所有节点。

  4. 打开架构的上下文菜单(右键菜单)。

  5. 打开存储过程节点的上下文菜单(右键菜单),然后选择转换脚本(操作类似转换数据库对象)。

  6. (可选)您也可以选择查看评估报告并应用转换。


以下是 SQL Server DW 存储过程转换的示例:



小结

Amazon Redshift 存储过程支持功能现已在所有 AWS 区域正式发布。我们希望您和我们一样对于能够在 Amazon Redshift 中运行存储过程感到兴奋。


借助 Amazon Redshift 和 AWS Schema Conversion Tool 对存储过程的支持,您现在可以将存储过程迁移到 Amazon Redshift,无需使用其他语言或框架进行编码。这一功能减少了迁移的工作量。我们希望更多本地客户可以利用 Amazon Redshift 并迁移到云中,以实现数据库自由




作者介绍:


Joe Harris 是 AWS 的高级 Redshift 数据库工程师,专注于 Redshift 性能问题研究他从事各种平台数据分析和数据仓库构建工作已有二十年之久。在加入 AWS 之前,自 2013 年 Redshift 发布时,他就一直是 Redshift 客户,同时也是 Redshift 论坛中的杰出贡献者


Abhinav Singh 是 AWS 的一名数据库工程师。他负责数据库迁移项目的设计和开发工作,并就数据库迁移项目为客户提供指导和技术帮助,助力客户使用 AWS 提高解决方案的价值。


Entong Shen 在 Amazon Redshift 查询处理团队担任高级软件工程师。他从事 MPP 数据库相关工作已 7 年有余,专注于查询优化、统计信息和 SQL 语言功能研究。业余时间,他喜欢听着各种流派的音乐在花园中当一名快乐的园丁。


Vinay 是 Amazon Web Services 的 Amazon Redshift 首席产品经理。此前,他曾在 Teradata 担任过产品部门高级总监,在 Hortonworks 担任过产品总监。在 Hortonworks,他推出了 Data Science、Spark、Zeppelin 和 Security 领域的产品。工作之余,Vinay 喜欢做瑜伽或外出远足。


**



Sushim Mitra 是 Amazon Redshift 查询处理团队的一名软件开发工程师。**他主要负责处理查询优化问题、SQL 语言功能和数据库安全性。工作之余,他喜欢阅读世界各地的小说。


本文转载自 AWS 技术博客。


原文链接:https://amazonaws-china.com/cn/blogs/china/big-data-bringing-your-stored-procedures-to-amazon-redshift/


2020-01-02 14:431052

评论

发布
暂无评论
发现更多内容

洗车行业前景好不如开个自助洗车店

共享电单车厂家

自助洗车加盟 开自助洗车店

为什么PO的角色在Scrum框架中不可替代

ShineScrum

Scrum 产品经理 PO 产品负责人

关键点标注的酷炫,你想象不到

澳鹏Appen

人工智能 数据标注 数据训练 关键点检测 关键点

字节跳动数据库的过去、现状与未来

火山引擎开发者社区

数据库 微服务 分布式数据库

特别的儿童节,OceanBase 送上一份特别的惊喜

OceanBase 数据库

oceanbase

24小时无人自助洗车要如何加盟?

共享电单车厂家

自助洗车加盟

孩子上网冲浪更安全,这份儿童节礼物值得拥有

最新动态

儿童节,和 AI 一起通关 “超级马里奥兄弟”

华为云开发者联盟

应用实践|Lifewit 数据平台基于Apache Doris的建设实践

SelectDB

数据库 数据仓库 apache doris SelectDB

使用Sonar来优化您的基础架构代码

龙智—DevSecOps解决方案

漏洞 SonarQube

从冬奥跳台飞跃向千家万户:联通“臻宽带”的起跳瞬间

脑极体

看完这篇异地多活的改造,我决定和架构师battle一下 / 得物技术

得物技术

架构 容灾 双活 双活容灾 异地多活

雅加达利用SAS优化抗疫救助资金发放,帮助中小微企业度过难关

E科讯

MSVC编译动态库

Loken

音视频 5月月更

字节跳动一站式数据治理解决方案及平台架构

字节跳动数据平台

数据治理 元数据

展示 Postlight 的 WordPress + React Starter Kit

海拥(haiyong.site)

WordPress 6月月更

将虚幻引擎5与Perforce Helix Core集成使用吧!

龙智—DevSecOps解决方案

perforce 虚幻引擎5 Helix Core

换个角度带你学C语言的基本数据类型

华为云开发者联盟

开发 C语言 数据类型位数

深入剖析 | HeartBeat方案的标准设计

九叔(高翔龙)

架构 dubbo 源码解析 HeartBeat 心跳设计

OpenHarmony 3.1 Release版本关键特性解析——OpenHarmony新音视频引擎——HiStreamer

OpenHarmony开发者

Open Harmony

C#入门系列(一) -- 初识C#语言

陈言必行

C# 6月月更

将不费吹灰之力成为卷王的秘籍传授于你!

龙智—DevSecOps解决方案

Jira插件 龙智自研插件 Jira飞书插件

了解es6语法简介

小恺

6月月更

那些年,我们在Apache SeaTunnel 2.1.0部署中踩过的坑【含源码分析】

Apache SeaTunnel

Apache 大数据 开源 workflow Seatunnel

有了这个云端Mock功能,你的简历起码提升30分!

Liam

前端 Postman 前端教程 API文档 前端工具

InfoQ 极客传媒 15 周年庆!无限生长未来可期!

InfoQ写作社区官方

热门活动 InfoQ极客传媒15周年庆

DataPipeline:让数据生产力的历史进程,再前进一步

DataPipeline数见科技

DataOps 数据管理

八大误区,逐个击破:担忧安全防护与合规性?这可能是您对云最大的误解

龙智—DevSecOps解决方案

Atlassian atlassian云版 Atlassian白皮书

自助洗车机还能加盟你不知道吧?

共享电单车厂家

自助洗车机 自助洗车加盟

6元自助洗车机一般都什么价位

共享电单车厂家

自助洗车加盟 6元自助洗车机

常遇到读多写少,教你用ReadWriteLock实现一个通用的缓存中心

华为云开发者联盟

缓存 高并发 开发 ReadWriteLock

将存储过程迁移到 Amazon Redshift(二)_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章