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 语句
相关推荐
XDHCOM1 天前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜1 天前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage1 天前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
一轮弯弯的明月1 天前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
liliangcsdn1 天前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜1 天前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick19931 天前
SQL 执行流程
数据库·sql
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
猿小喵1 天前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
航Hang*1 天前
第3章:Linux系统安全管理——第2节:部署代理服务
linux·运维·服务器·开发语言·笔记·系统安全