Azure SQL Database (21) 将整张表都迁移到Azure Stretch Database里-阿里云开发者社区

开发者社区> zting科技> 正文

Azure SQL Database (21) 将整张表都迁移到Azure Stretch Database里

简介:
+关注继续查看

 《Windows Azure Platform 系列文章目录

 

   Azure SQL Database (19) Stretch Database 概览

     Azure SQL Database (20) 使用SQL Server 2016 Upgrade Advisor

     Azure SQL Database (21) 将整张表都迁移到Azure Stretch Database里

     Azure SQL Database (22) 迁移部分数据到Azure Stretch Database 

 

 

  注意:本节介绍的是,使用国内由世纪互联运维的Azure China Stretch Database,因为国内的Azure和海外的Azure对应的DNS Name略有不同,请读者仔细甄别

 

  本节使用的T-SQL语句,在这里下载

 

 

  在上一节内容中,Azure SQL Database (20) 使用SQL Server 2016 Upgrade Advisor

  我们发现Sales.OrderTraking这张表,可以迁移到Azure Stretch Database。没有兼容性问题

  

 

  接下来,本章将介绍如何将这张表的所有内容,都迁移到Azure Stretch Database里。

 

  准备工作:

  1.首先我们使用Azure China管理平台:https://manage.windowsazure.cn/

  输入Azure China的用户名和密码,然后登陆。

  2.点击SQL是数据库,添加新的SQL Database Server服务器(请注意:是创建Server,不是创建Database,单独创建Server不会产生任何费用)

  

  3.创建的时候,记得选择"启用最新的SQL数据库更新(V12)"

  

  笔者已经预先创建了云上的Server Name: l3cq1dckpd

  用户名:sqladmin,密码:Abc@123456

  注意哦,这些信息下面会使用的。

 

  4.创建完毕后,记得把本地笔记本的公网IP地址,加入到Azure SQL Database Server的IP白名单里。

  

  

 

 

 

  开始使用:

  1.我们在本地笔记本电脑,打开SQL Server Management Studio (SSMS),运行以下T-SQL语句。  

USE AdventureWorks2016CTP3
GO

SELECT ot.SalesOrderID, ot.CarrierTrackingNumber, ot.OrderTrackingID, ot.TrackingEventID, te.EventName, ot.EventDetails, ot.EventDateTime FROM Sales.OrderTracking ot JOIN Sales.TrackingEvent te ON ot.TrackingEventID
= te.TrackingEventID ORDER BY ot.SalesOrderID, ot.TrackingEventID;

  可以观察到,因为数据表都保存在本地SQL Server 2016数据库中,所以虽然一共有188790行,但是查询结果不超过2秒

 

  2.运行以下T-SQL语句,对本地SQL Server 2016,打开归档功能

EXEC sp_configure 'remote data archive' , '1';
RECONFIGURE;

 

  3.对云端Azure SQL Database的用户名和密码,进行加密,加密的密码同SQL Database的密码:

USE Adventureworks2016CTP3;
CREATE MASTER KEY ENCRYPTION BY PASSWORD='Abc@123456'
CREATE DATABASE SCOPED CREDENTIAL AzureDBCred WITH IDENTITY = 'sqladmin', SECRET = 'Abc@123456';

 

  4.将本地的SQL Server 2016的归档目标,指向到微软云SQL Database Server(l3cq1dckpd.database.chinacloudapi.cn)

  这个l3cq1dckpd.database.chinacloudapi.cn,是我们在准备工作中,创建的新的服务器

ALTER DATABASE [AdventureWorks2016CTP3] SET REMOTE_DATA_ARCHIVE = ON 
(SERVER = 'l3cq1dckpd.database.chinacloudapi.cn', CREDENTIAL = AzureDBCred);

  上面的语句执行时间有点长。请注意:到目前为止,还没有任何的本地SQL Server 2016表数据,迁移到云端Stretch Database里。

 

 

  5.运行以下T-SQL,将Sales.OrderTracking表中的所有内容,都迁移到Azure Stretch Database里

  注意:MIGRATION_STATE = OUTBOUND

ALTER TABLE Sales.OrderTracking SET (REMOTE_DATA_ARCHIVE = ON (MIGRATION_STATE = OUTBOUND));

  运行完毕后,本地SQL 2016数据库中的表Sales.OrderTracking的所有数据行,才开始异步迁移

 

  6.请注意,执行步骤5的语句的时候,其实数据是异步进行迁移的

  我们可以执行以下语句,查看归档数据迁移的进度。

SELECT * from sys.dm_db_rda_migration_status

  注意:如果上面的语句执行没有结果,请稍等片刻后继续执行。会看到以下结果:

  请注意:时间为UTC时区,Migrated_Rows表示已经迁移到云端的Stretch Database的数据行,可以看到每次迁移的数据量是9999行

 

 

  7.等到步骤6中的T-SQL产生执行结果了,我们分别执行以下语句。

复制代码
USE AdventureWorks2016CTP3
GO
--显示本地数据行和数据容量
EXEC sp_spaceused 'Sales.OrderTracking', 'true', 'LOCAL_ONLY';
GO

--显示云端Stretch Database的数据行和数据量
EXEC sp_spaceused 'Sales.OrderTracking', 'true', 'REMOTE_ONLY';
GO
复制代码

  执行结果如下图:

  

  图的上半部分,显示本地SQL Server 2016的表Sales.OrderTracking,一共有数据行188790

  下半部分,显示云端的Stretch Database的表Sales.OrderTracking,一共有0行数据

 

  8.我们稍等片刻后,继续执行步骤7的语句。结果如下图:

  

  可以看到,本地SQL Server 2016的表Sales.OrderTracking的所有数据,都迁移到了云端Stretch Database。

  本地0行,云端Stretch Database 188790行。

 

  9.我们登陆Azure China管理平台:https://manage.windowsazure.cn/

  可以看到在云端,已经有新的Stretch Database,版本为 DS100

  

  

  10.然后我们重复执行步骤1中的查询语句,因为Sales.OrderTracking数据从本地迁移到了云端,所以查询时间变长了。

  之前本地执行2秒,现在在云端查询,需要18秒左右。图略。

 

  11.请记住,可以迁移到云端(但未迁移)的SQL数据(表Table或者试图View),或者已经迁移到Stretch Database云端的SQL数据,无法执行UPDATE和DELETE操作

  插入测试数据到云端Stretch Database的表Sales.OrderTracking,没问题:

---插入测试表
INSERT INTO [Sales].[OrderTracking]
([SalesOrderID],[CarrierTrackingNumber],[TrackingEventID],[EventDetails],[EventDateTime])
VALUES('6666','046DFAA-F901-442A-9D09-67',1,'This Data is generated by Lei Zhang',GetDate())

  但是无法执行UPDATE和DELETE操作

--这句话会报错
UPDATE [Sales].[OrderTracking] SET [CarrierTrackingNumber]='6666' WHERE [EventDetails]='This Data is generated by Lei Zhang'

 

  12.现在表Sales.OrderTracking数据都保存到云端Stretch Database,如果我们想关闭归档功能,可以执行以下语句。

--Disable Stretch Database and bring back remote data
ALTER TABLE Sales.OrderTracking SET (REMOTE_DATA_ARCHIVE (MIGRATION_STATE = INBOUND));

 

  13.重复执行步骤7的语句,可以观察到数据异步从云端,迁移到本地SQL 2016。

复制代码
USE AdventureWorks2016CTP3
GO
--显示本地数据行和数据容量
EXEC sp_spaceused 'Sales.OrderTracking', 'true', 'LOCAL_ONLY';
GO

--显示云端Stretch Database的数据行和数据量
EXEC sp_spaceused 'Sales.OrderTracking', 'true', 'REMOTE_ONLY';
GO
复制代码

  执行结果略。

 

 

  14.最后请大家记住,如果要完全关闭归档功能,除了执行步骤13以外,还需要登陆Azure China管理平台:https://manage.windowsazure.cn/

  删除之前迁移产生的数据库。

  

 



本文转自Lei Zhang博客园博客,原文链接:http://www.cnblogs.com/threestone/p/5826310.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9480 0
数据迁移工具DataX部署与使用
概述 DataX 是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括 MySQL、Oracle、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS)、MaxCompute(ODPS)、DRDS 等各种异构数据源之间高效的数据同步功能。
4334 0
使用DataX进行OTS实例间数据迁移
本文主要说明在业务不停服的前提下如何实现对OTS的增量迁移,以及迁移后的数据一致性校验
3298 0
DTS开发记录(9)-- 数据迁移任务 DataTask
在DTS开发记录(1)--系统总体结构 一文中,我们已经看到,一次数据传递任务基于一个连接对和一个数据映射进行。但是之前,我们并没有提到“数据迁移任务”这个元素。随着设计的演化,我们发现一个数据任务已经不再仅仅是一个连接对加上一个数据映射了。
862 0
自建Hive数据仓库跨版本迁移到阿里云Databricks数据洞察
客户在IDC或者公有云环境自建Hadoop集群构建数据仓库和分析系统,购买阿里云Databricks数据洞察集群之后,涉及到数仓数据和元数据的迁移以及Hive版本的订正更新。
134 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13163 0
MyBatis Generator(MBG)从Abator迁移
此页面详细介绍MyBatis Generator(MBG)和Abator之间的变化。对于大多数用户而言,更改应该很简单。如果您扩展了Abator的任何类以提供代码生成器或Java类型解析器的自定义实现,则需要重新编写这些自定义类。
912 0
MyBatis Generator(MBG)从Ibator迁移
此页面详细介绍MyBatis Generator(MBG)和Ibator之间的更改。对于大多数用户而言,更改应该很简单。如果您扩展了Ibator的任何类以提供代码生成器或Java类型解析器的自定义实现,则需要重新编写这些自定义类。
732 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
11499 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
6884 0
+关注
3550
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载