Azure SQL Database (22) 迁移部分数据到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 

 

 

  在之前的文档中,笔者介绍了如何迁移一张表的所有数据,到云端Stretch Database

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

 

  在这里,笔者介绍如何将一张表里的部分数据,迁移到云端Stretch Database里。

  更多的内容,请参考MSDN文章:https://msdn.microsoft.com/en-us/library/mt613432.aspx

 

  准备工作:

  1.如果你已经开始之前的练习,请删除之前在本地的Sample Database:AdventureWorks2016CTP3

  2.登陆Azure China管理平台:https://manage.windowsazure.cn/删除Stretch Database

  

  3.重新还原AdventureWorks2016CTP3

 

  基本定义:

  我们可以在本地SQL Server 2016,创建以下方法Function

CREATE FUNCTION dbo.fn_stretchpredicate(@column1 datatype1, @column2 datatype2 [, ...n])  
RETURNS TABLE  
WITH SCHEMABINDING   
AS   
RETURN  SELECT 1 AS is_eligible  
        WHERE <predicate>  

 

  返回值:

  如果返回的值为非空(non-empty)的话,则这些返回结果会被迁移到云端Stretch Database。

  剩下的值(即不在这些返回值中的内容),则会保留在本地SQL Server 2016

 

  条件:

  这里的条件,就是<predicate> 参数。

 

  我们还是以数据库AdventureWorks2016CTP3,表Sales.OrderTracking为例。

  1.首先打开本地计算机的SQL Server Management Studio(SSMS),运行以下脚本:

USE AdventureWorks2016CTP3
--Review the Data
SELECT COUNT(*) FROM Sales.OrderTracking WHERE TrackingEventID <= 3
--Review the Data
SELECT COUNT(*) FROM Sales.OrderTracking WHERE TrackingEventID > 3

  可以看到,TrackingEventID <= 3的数据量为94364。TrackingEventID>3的数据量为94426。图略。

 

  接下来的几个步骤,同之前的文档,主要作用是设置和打开归档功能。

复制代码
--对本地SQL Server 2016,打开归档功能
EXEC sp_configure 'remote data archive' , '1';
RECONFIGURE;

--对云端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';

--将本地的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);
复制代码

 

   2.然后我们计划把TrackingEventID <= 3的值(一共94364行),都保存到云端Stretch Database。

 

  3.我们在本机SSMS,执行以下T-SQL语句。创建FUNCTION

--Create Function
CREATE FUNCTION dbo.fn_stretchpredicate(@status int) 
RETURNS TABLE WITH SCHEMABINDING AS 
RETURN    SELECT 1 AS is_eligible WHERE @status <= 3; 

 

  4.开始迁移数据表中的部分数据

--Migrate Some Data to the Cloud
ALTER TABLE Sales.OrderTracking SET (REMOTE_DATA_ARCHIVE = ON (
    MIGRATION_STATE = OUTBOUND,
    FILTER_PREDICATE = dbo.fn_stretchpredicate(TrackingEventId)));

 

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

SELECT * from sys.dm_db_rda_migration_status

 

  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
复制代码

  执行结果:

  如上图所示:Sales.OrderTracking保存在本地的数据有94426行

  Sales.OrderTracking保存在云端Stretch Database的数据有94364行

 

 

  

  参考资料:https://msdn.microsoft.com/en-us/library/mt613432.aspx

 



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

目录
相关文章
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
简介:本文整理自阿里云高级技术专家李麟在Flink Forward Asia 2025新加坡站的分享,介绍了Flink 2.1 SQL在实时数据处理与AI融合方面的关键进展,包括AI函数集成、Join优化及未来发展方向,助力构建高效实时AI管道。
1071 43
|
8月前
|
SQL 人工智能 JSON
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
本文整理自阿里云的高级技术专家、Apache Flink PMC 成员李麟老师在 Flink Forward Asia 2025 新加坡[1]站 —— 实时 AI 专场中的分享。将带来关于 Flink 2.1 版本中 SQL 在实时数据处理和 AI 方面进展的话题。
486 0
Flink 2.1 SQL:解锁实时数据与AI集成,实现可扩展流处理
|
9月前
|
SQL
SQL如何只让特定列中只显示一行数据
SQL如何只让特定列中只显示一行数据
|
9月前
|
SQL
SQL中如何删除指定查询出来的数据
SQL中如何删除指定查询出来的数据
|
9月前
|
SQL 关系型数据库 MySQL
SQL如何对不同表的数据进行更新
本文介绍了如何将表A的Col1数据更新到表B的Col1中,分别提供了Microsoft SQL和MySQL的实现方法,并探讨了多表合并后更新的优化方式,如使用MERGE语句提升效率。适用于数据库数据同步与批量更新场景。
|
SQL 存储 数据库
SQL Azure的第三方工具介绍(下)
一、概述 Windows Azure毕竟是新兴的云计算平台,其三大组成部分之一的SQL Azure关系型云数据库引擎提供的功能还不够丰富。有鉴于此,一些公司和开发者为了满足用户的需要,开发了一些优秀的工具,下面对这些第三方工具做一个概要性的介绍。
1127 0
|
SQL 存储 数据库
SQL Azure的第三方工具介绍(下)
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/7842942 回报CSDN! 一、概述 Windows Azure毕竟是新兴的云计算平台,其三大组成部分之一的SQL Azure关系型云数据库引擎提供的功能还不够丰富。
958 0
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
727 13
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
523 9