好书分享,面向开发者的Azure SQL Database最佳实践,也适用SQL Server 2016以上的版本。应对不同场景使用的数据库功能,包括内存表,列存储表,非聚集列存储索引,JSON等等。

下载地址:

https://all-ebook.info/9978-practical-azure-sql-database-for-modern-developers.html

基础SQL

Subqueries

Common Table Expressions

Union

Merge

MERGE INTO

[Warehouse].[Colors] AS [target]

USING

(VALUES

(50, 'Deep Sea Blue'),

(51, 'Deep Sea Light Blue'),

(52, 'Deep Sea Dark Blue')

) [source](Id, [Name])

ON

[target].[ColorID] = [source].[Id]

WHEN MATCHED THEN

UPDATE SET [target].[ColorName] = [source].[Name]

WHEN NOT MATCHED THEN

INSERT ([ColorID], [ColorName], [LastEditedBy]) VALUES ([source].Id,

[source].[Name], 1)

WHEN NOT MATCHED BY SOURCE AND [target].[ColorID] BETWEEN 50 AND 100 THEN

DELETE

Windowing Functions

SELECT

[OrderID],

[OrderLineID],

[Description],

[Quantity],

SUM(Quantity) OVER ( PARTITION BY [OrderID] ORDER BY [OrderLineID] ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS RunningTotal

FROM

[Sales].[OrderLines]

WHERE

[OrderID] in (37, 39)

进阶SQL

Variables

T-SQL doesn't support arrays, lists, or dictionaries, you can use a Table Variable

DECLARE @t AS TABLE (

[Id] INT NOT NULL,

[Name] NVARCHAR(50) NOT NULL

);

INSERT INTO @t VALUES (42, N'John');

SELECT * FROM @t;

Temporary Tables

Views

Functions

Stored Procedures

使用json传递多值参数

CREATE OR ALTER PROCEDURE dbo.GetOrderForCustomer

@CustomerInfo NVARCHAR(MAX)

AS

IF (ISJSON(@CustomerInfo) != 1) BEGIN

THROW 50000, '@CustomerInfo is not a valid JSON document', 16

END

SELECT [Value] INTO #T FROM OPENJSON(@CustomerInfo, '$.CustomerId') AS ci;

SELECT

[CustomerID],

COUNT(*) AS OrderCount,

MIN([OrderDate]) AS FirstOrder,

MAX([OrderDate]) AS LastOrder

FROM

Sales.[Orders]

WHERE

[CustomerID] IN (SELECT [Value] FROM #T)

GROUP BY

[CustomerID];

EXEC dbo.GetOrderForCustomer N'{"CustomerId": [106, 193, 832]}';

unless you have some specific use case that is perfectly suited for a Function, the recommendation is to use Stored Procedures

永远不要用触发器了

JSON

动态参数,拓展属性列,弹性域

CSV

STRING_SPLIT

CREATE PROCEDURE dbo.AddTagsToPost

@PostId INT,

@Tags NVARCHAR(MAX)

AS

INSERT INTO dbo.PostTags

SELECT @PostId, T.[value] FROM STRING_SPLIT(@Tags, '|') AS T

EXEC dbo.AddTagsToPost 1, 'azure-sql|string_split|csv'

Change Tracking

CDC

替代方案Debezium+ Kafka

Row-Level Security

CREATE FUNCTION rls.LoginSecurityPolicy(@PersonID AS INT)

RETURNS TABLE

WITH SCHEMABINDING

AS

RETURN

SELECT

1 As [Authorized]

FROM

[Application].[People]

WHERE

LoginName = SESSION_CONTEXT(N'Login')

AND

PersonID = @PersonId;

system function SESSION_CONTEXT to retrieve the value of the Logon key

Dynamic Data Masking

Always Encrypted

多模

JSON

SELECT

severity,

ip = JSON_VALUE(log, '$.ip'),

duration = AVG(CAST(JSON_VALUE(log,'$.duration') as int))

FROM

WebSite.Logs

WHERE

CAST(JSON_VALUE(log,'$.date') as datetime) > @datetime

GROUP BY

severity, JSON_VALUE(log, '$.ip')

HAVING

AVG(CAST(JSON_VALUE(log,'$.duration') as int) ) > 100

ORDER BY

AVG(CAST(JSON_VALUE(log,'$.duration') as int) );

ALTER TABLE Webite.Logs

ADD CONSTRAINT [Data should be formatted as JSON]

CHECK (ISJSON(log) = 1);

CREATE CLUSTERED COLUMNSTORE INDEX cci ON WebSite.Logs;

alter table WebSite.Logs

add [$severity] AS JSON_VALUE(log, '$.severity');

go

create index ix_severity on WebSite.Logs ([$severity]);

Graph

Spatial data

XML data

Key-value

Azure SQL doesn't have a specialized structure that holds key-value pairs.

With memory-optimized tables, you can index the key column using B-tree or Hash indexes-使用内存表代替

CREATE TABLE [Cache] (

[key] BIGINT IDENTITY,

value NVARCHAR(MAX),

INDEX IX_Hash_Key HASH ([key]) WITH (BUCKET_COUNT = 100000)

) WITH (MEMORY_OPTIMIZED = ON, DURABILITY = SCHEMA_ONLY);

More Than Tables

列存储表

聚集列存储表

非聚集列存储索引

内存表

using classic rowstore tables with NCCI indexes for HTAP scenarios is the general approach,

Memory-Optimized Clustered Columnstore Indexes are used only on very performance-intensive workloads.

--Columnstore memory-optimized tables

CREATE TABLE Accounts (

AccountKey int NOT NULL PRIMARY KEY NONCLUSTERED,

Description nvarchar (50),

Type nvarchar(50),

UnitSold int,

INDEX cci CLUSTERED COLUMNSTORE

) WITH (MEMORY_OPTIMIZED = ON, DURABILITY = SCHEMA_AND_DATA)

--memory-optimized tables and the NONCLUSTERED HASH index

CREATE TABLE [dbo].[Employees](

[EmpID] [int] NOT NULL

CONSTRAINT PK_Employees_EmpID PRIMARY KEY

NONCLUSTERED HASH (EmpID) WITH (BUCKET_COUNT = 100000),

[EmpName] [varchar](50) NOT NULL,

[EmpAddress] [varchar](50) NOT NULL,

[EmpDEPID] [int] NOT NULL,

[EmpBirthDay] [datetime] NULL

) WITH (MEMORY_OPTIMIZED = ON, DURABILITY = SCHEMA_AND_DATA)

Natively compiled code

CREATE FUNCTION PeopleData(@json nvarchar(max))

RETURNS TABLE

WITH NATIVE_COMPILATION, SCHEMABINDING

AS RETURN (

SELECT Title, HireDate, PrimarySalesTerritory,

CommissionRate, OtherLanguages

FROM OPENJSON(@json)

WITH(Title nvarchar(50),

HireDate datetime2,

PrimarySalesTerritory nvarchar(50),

CommissionRate float,

OtherLanguages nvarchar(max) AS JSON)

)

--调用函数

select p.FullName, p.EmailAddress, j.Title, j.CommissionRate

from Application.People p

cross apply PeopleData(p.CustomFields) j

Temporal tables

--当前表使用内存表

--历史表使用列存储表+非聚集行索引

CREATE CLUSTERED COLUMNSTORE INDEX cci_DepartmentHistory

ON DepartmentHistory;

CREATE NONCLUSTERED INDEX IX_DepartmentHistory_ID_PERIOD_COLUMNS

ON DepartmentHistory (SysEndTime, SysStartTime, DeptID);

HTAP

列存储索引+内存表做实时混合负载,HTAP场景

https://docs.microsoft.com/zh-cn/sql/relational-databases/indexes/get-started-with-columnstore-for-real-time-operational-analytics?view=sql-server-ver15

本书作者的博客

https://github.com/yorek

insert if not exists

insert into [dbo].[tags] ([post_id], [tag])

select * from (

values (10, 'tag123') -- sample value

) as s([post_id], [tag])

where not exists (

select * from [dbo].[tags] t with (updlock)

where s.[post_id] = t.[post_id] and s.[tag] = t.[tag]

)

https://devblogs.microsoft.com/azure-sql/the-insert-if-not-exists-challenge-a-solution/

多行插入使用JSON, Table Valued Parameters,与MERGE的比较

key-value store性能测试

https://devblogs.microsoft.com/azure-sql/azure-sql-database-as-a-key-value-store/

IoT场景性能测试

https://devblogs.microsoft.com/azure-sql/ingest-millions-of-events-per-second-on-azure-sql-leveraging-shock-absorber-pattern/

JSON性能测试

https://devblogs.microsoft.com/azure-sql/json-in-your-azure-sql-database-lets-benchmark-some-options/

开源web sql编辑器SQLPad

https://devblogs.microsoft.com/azure-sql/querying-and-visualizing-data-using-sqlpad/

DevOps for Azure SQL

https://devblogs.microsoft.com/azure-sql/devops-for-azure-sql/

SQL Database for Modern Developers的更多相关文章

  1. HTML5教程之html 5 本地数据库(Web Sql Database)

    HTML5的Web SQL Databases(html5 本地数据库)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的.今天,我们一起来了解HTM ...

  2. Azure SQL Database (19) Stretch Database 概览

    <Windows Azure Platform 系列文章目录>  Azure SQL Database (19) Stretch Database 概览      Azure SQL Da ...

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

    <Windows Azure Platform 系列文章目录>  Azure SQL Database (19) Stretch Database 概览      Azure SQL Da ...

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

    <Windows Azure Platform 系列文章目录>  Azure SQL Database (19) Stretch Database 概览      Azure SQL Da ...

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

    <Windows Azure Platform 系列文章目录>  Azure SQL Database (19) Stretch Database 概览      Azure SQL Da ...

  6. Azure SQL Database Active Geo-Replication简介

    笔者在<迁移SQL Server 数据库到 Azure SQL 实战>一文中,介绍了如何把一个本地版的 SQL Server 数据库迁移到 Azure SQL Database.迁移虽然顺 ...

  7. HTML5本地存储——Web SQL Database

    在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...

  8. HTML5 学习笔记(三)——本地存储(LocalStorage、SessionStorage、Web SQL Database)

    一.HTML4客户端存储 B/S架构的应用大量的信息存储在服务器端,客户端通过请求响应的方式从服务器获得数据,这样集中存储也会给服务器带来相应的压力,有些数据可以直接存储在客户端,传统的Web技术中会 ...

  9. web sql database数据存储位置

    Q1: 数据存储在哪儿? Web Storage / Web SQL Database / Indexed Database 的数据都存储在浏览器对应的用户配置文件目录(user profile di ...

随机推荐

  1. Codeforces Round #658 (Div. 2) D. Unmerge (思维,01背包)

    题意:有两个数组\(a\)和\(b\),每次比较它们最左端的元素,取小的加入新的数组\(c\),若\(a\)或\(b\)其中一个为空,则将另一个全部加入\(c\),现在给你一个长度为\(2n\)的数组 ...

  2. 10.PowerShell DSC之细节

    mof文件到各Node放在哪里了? 在C:\Windows\System32\Configurtion文件夹下: 你可能会注意到mof的文件名称和Pull Server上的不一致,并且多出了几个.不用 ...

  3. Git 初始化及仓库创建及操作

    一.基本信息设置 1.初始化设置用户名 2.初始化设置用户名邮箱 备注:该设置在Github仓库主页显示谁提交了该文件. 二.初始化一个新的Git仓库 1.创建文件夹 mkdir test 2.在文件 ...

  4. 【转】Dockerfile

    1. 关于docker build  docker build可以基于Dockerfile和context打包出一个镜像,其中context是一系列在PATH或URL中指定的位置中的文件(contex ...

  5. python工业互联网应用实战6—任务分解

    根据需求定义"任务"是一个完整的业务搬运流程,整个流程涉及到多个机构(设备)分别动作执行多个步骤,所以依据前面的模型设计,需要把任务分解到多个连续的子任务(作业),未来通过顺序串联 ...

  6. ZOJ 3494 BCD Code(AC自动机 + 数位DP)题解

    题意:每位十进制数都能转化为4位二进制数,比如9是1001,127是 000100100111,现在问你,在L到R(R <= $10^{200}$)范围内,有多少数字的二进制表达式不包含模式串. ...

  7. codevs1039整数的k划分-思考如何去重复

    题目描述将整数n分成k份,且每份不能为空,任意两种划分方案不能相同(不考虑顺序).例如:n=7,k=3,下面三种划分方案被认为是相同的.1 1 51 5 15 1 1问有多少种不同的分法.输入描述输入 ...

  8. 记一次 Billu_b0x渗透

    目录: 0x01 寻找ip 1.这边我们是使用的nmap来寻找我们的靶机IP地址,开始Ip是1,结束是254,153是我kali的ip,所以158就是我们的靶机的ip地址了. 2. 查看端口服务 这边 ...

  9. 013.NET5_MVC_Razor扩展Html控件01

    Razor扩展控件  第一种方式: 1. 定义一个静态类 2. 定义静态扩展方法,扩展IHtmlHelper类型,返回IHtmlContent类型: 本质:通过后台方法,返回一个已经存在的Html标签 ...

  10. PDF transform to PPT online & free

    PDF transform to PPT online & free > Speaker Deck Share Presentationswithout the Mess Speaker ...