SQL Server笔记 -- 第68章:内存中 OLTP(Hekaton)

68.1 声明内存优化表变量

为获得更高性能,可将表变量改为内存优化。传统表变量示例:

sql 复制代码
DECLARE @tvp TABLE (
  col1 INT NOT NULL,
  col2 CHAR(10)
);

使用内存优化版本,需先创建内存优化表类型,再声明变量:

sql 复制代码
CREATE TYPE dbo.memTypeTable AS TABLE (
  Col1 INT NOT NULL INDEX ix1,
  Col2 CHAR(10)
) WITH (MEMORY_OPTIMIZED = ON);
GO

DECLARE @tvp memTypeTable;
INSERT INTO @tvp VALUES (1,'1'),(2,'2'),(3,'3'),(4,'4'),(5,'5'),(6,'6');
SELECT * FROM @tvp;

68.2 创建内存优化表

sql 复制代码
-- 创建示例数据库
CREATE DATABASE SQL2016_Demo
ON PRIMARY (
  NAME = N'SQL2016_Demo',
  FILENAME = N'C:\Dump\SQL2016_Demo.mdf',
  SIZE = 5120KB,
  FILEGROWTH = 1024KB
)
LOG ON (
  NAME = N'SQL2016_Demo_log',
  FILENAME = N'C:\Dump\SQL2016_Demo_log.ldf',
  SIZE = 1024KB,
  FILEGROWTH = 10%
);
GO

USE SQL2016_Demo;
GO

-- 添加内存优化文件组
ALTER DATABASE SQL2016_Demo
ADD FILEGROUP MemFG CONTAINS MEMORY_OPTIMIZED_DATA;
GO

-- 向文件组添加文件
ALTER DATABASE SQL2016_Demo
ADD FILE (
  NAME = MemFG_File1,
  FILENAME = N'C:\Dump\MemFG_File1'
) TO FILEGROUP MemFG;
GO

-- 创建内存优化表(持久性可选 SCHEMA_AND_DATA 或 SCHEMA_ONLY)
CREATE TABLE dbo.MemOptTable1 (
  Column1 INT NOT NULL,
  Column2 NVARCHAR(4000) NULL,
  SpidFilter SMALLINT NOT NULL DEFAULT (@@spid),
  INDEX ix_SpidFilter NONCLUSTERED (SpidFilter),
  INDEX ix_SpidFilter HASH (SpidFilter) WITH (BUCKET_COUNT = 64),
  CONSTRAINT CHK_soSessionC_SpidFilter CHECK (SpidFilter = @@spid)
) WITH (
  MEMORY_OPTIMIZED = ON,
  DURABILITY = SCHEMA_AND_DATA
);
GO

CREATE TABLE MemOptTable2 (
  ID INT NOT NULL PRIMARY KEY NONCLUSTERED HASH WITH (BUCKET_COUNT = 10000),
  FullName NVARCHAR(200) NOT NULL,
  DateAdded DATETIME NOT NULL
) WITH (MEMORY_OPTIMIZED = ON, DURABILITY = SCHEMA_AND_DATA);
GO

68.3 查看生成的 DLL 文件与内存优化表

sql 复制代码
SELECT OBJECT_ID('MemOptTable1') AS MemOptTable1_ObjectID,
       OBJECT_ID('MemOptTable2') AS MemOptTable2_ObjectID;
GO

SELECT name, description
FROM sys.dm_os_loaded_modules
WHERE name LIKE '%XTP%';
GO

-- 列出所有内存优化表
SELECT name, type_desc, durability_desc, is_memory_optimized
FROM sys.tables
WHERE is_memory_optimized = 1;
GO

68.4 创建内存优化的系统版本化时态表

sql 复制代码
CREATE TABLE dbo.MemOptimizedTemporalTable (
  BusinessDocNo BIGINT NOT NULL,
  ProductCode INT NOT NULL,
  UnitID TINYINT NOT NULL,
  PriceID TINYINT NOT NULL,
  SysStartTime DATETIME2(7) GENERATED ALWAYS AS ROW START NOT NULL,
  SysEndTime DATETIME2(7) GENERATED ALWAYS AS ROW END NOT NULL,
  PERIOD FOR SYSTEM_TIME (SysStartTime, SysEndTime),
  CONSTRAINT PK_MemOptimizedTemporalTable PRIMARY KEY NONCLUSTERED (
    BusinessDocNo ASC,
    ProductCode ASC
  )
) WITH (
  MEMORY_OPTIMIZED = ON,
  DURABILITY = SCHEMA_AND_DATA,
  SYSTEM_VERSIONING = ON (
    HISTORY_TABLE = History.MemOptimizedTemporalTable_History,
    DATA_CONSISTENCY_CHECK = ON
  )
);

68.5 内存优化表类型与临时表

传统表类型:

sql 复制代码
CREATE TYPE dbo.testTableType AS TABLE (
  col1 INT NOT NULL,
  col2 CHAR(10)
);

内存优化表类型(需加索引):

sql 复制代码
CREATE TYPE dbo.testTableType AS TABLE (
  col1 INT NOT NULL,
  col2 CHAR(10),
  INDEX ix NONCLUSTERED (col1)
) WITH (MEMORY_OPTIMIZED = ON);

全局临时表:

sql 复制代码
CREATE TABLE ##tempGlobalTable (
  Col1 INT NOT NULL,
  Col2 NVARCHAR(4000)
);

对应的内存优化版本(使用 SCHEMA_ONLY 持久性):

sql 复制代码
CREATE TABLE dbo.tempGlobalTable (
  Col1 INT NOT NULL INDEX ix NONCLUSTERED,
  Col2 NVARCHAR(4000)
) WITH (
  MEMORY_OPTIMIZED = ON,
  DURABILITY = SCHEMA_ONLY
);

迁移步骤:

  1. 按相同架构新建 SCHEMA_ONLY 内存优化表,并至少建一个索引
  2. 将代码中对 ##temp 的引用改为新表名
  3. 把 DROP TABLE ##temp 改为 DELETE FROM 新表 以清空数据
  4. 移除原 CREATE TABLE ##temp 语句
相关推荐
m0_7349497921 分钟前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
T.i.s23 分钟前
番外续2-MIT-BIH Arrhythmia Database
数据库
U盘失踪了35 分钟前
Playwright Trace 查看器
笔记
有味道的男人40 分钟前
AI 效率翻倍:对接 1688 拍立淘接口,商品全量信息一键抓取
数据库
m0_741173331 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
志栋智能1 小时前
超自动化巡检:解锁运维数据的深层价值
运维·服务器·数据库·自动化
m0_380113841 小时前
补单系统搭建及源码分享
数据库·spring boot·mybatis
步辞1 小时前
css伪类选择器-nth-child应用技巧_循环选择列表或表格行的实现方法
jvm·数据库·python
阿丰资源2 小时前
基于SpringBoot+MySQL的社区团购系统设计与实现(附源码+文档+数据库,直接运行)
数据库·spring boot·mysql
2301_803875612 小时前
Python怎么计算NumPy数组的切比雪夫距离_使用abs与max求解
jvm·数据库·python