0

0

SQLSERVER中KeyHashValue的作用(下)

php中文网

php中文网

发布时间:2016-06-07 15:45:45

|

1446人浏览过

|

来源于php中文网

原创

SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)SQLSERVER中KeyHashValue的作用(下)
1 SELECT   %%lockres%% AS '数据页的keyhashvalue' FROM  表名
1 DBCC TRACEON(3604,-1)
2 GO
3 DBCC PAGE(testhashkey,1,126,3) 
4 GO
 1 USE master
 2 GO
 3 CREATE DATABASE testhashkey
 4 GO
 5 
 6 USE testhashkey
 7 GO
 8 
 9 --------------------------------------------
10 --测试聚集索引
11 CREATE TABLE testcluster
12     (
13       a NVARCHAR(3800) NOT NULL ,
14       b INT NOT NULL
15     )
16 GO
17 
18 --这里一定要是唯一的
19 CREATE UNIQUE  CLUSTERED INDEX ucl ON testcluster(b)
20 GO
21 
22 INSERT  testcluster
23 SELECT  CAST(11 AS VARCHAR(10))+replicate('a', 3500),1 UNION ALL
24 SELECT  CAST(22 AS VARCHAR(10))+replicate('a', 3500),2
 1 CREATE TABLE DBCCResult (
 2 PageFID NVARCHAR(200),
 3 PagePID NVARCHAR(200),
 4 IAMFID NVARCHAR(200),
 5 IAMPID NVARCHAR(200),
 6 ObjectID NVARCHAR(200),
 7 IndexID NVARCHAR(200),
 8 PartitionNumber NVARCHAR(200),
 9 PartitionID NVARCHAR(200),
10 iam_chain_type NVARCHAR(200),
11 PageType NVARCHAR(200),
12 IndexLevel NVARCHAR(200),
13 NextPageFID NVARCHAR(200),
14 NextPagePID NVARCHAR(200),
15 PrevPageFID NVARCHAR(200),
16 PrevPagePID NVARCHAR(200)
17 )
18 
19 TRUNCATE TABLE [dbo].[DBCCResult]
20 
21 INSERT INTO DBCCResult EXEC ('DBCC IND(testhashkey,testcluster,-1) ')
22 
23 SELECT * FROM [dbo].[DBCCResult] ORDER BY [PageType] DESC 
1 select %%lockres%% AS '数据页的keyhashvalue' from testcluster
 1 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
 2 GO
 3 BEGIN TRANSACTION
 4 SELECT b FROM [dbo].[testcluster] WHERE [b]=1
 5 --COMMIT TRAN
 6 
 7 SELECT  resource_type ,
 8         resource_database_id ,
 9         resource_description ,
10         resource_associated_entity_id ,
11         request_mode ,
12         request_type ,
13         request_status
14 FROM    sys.dm_tran_locks
15 WHERE   [resource_database_id]=DB_ID('testhashkey')
16 ORDER BY [resource_type]
 1 USE master
 2 GO
 3 CREATE DATABASE practice
 4 GO
 5 
 6 USE practice
 7 GO
 8 
 9 --只有聚集索引
10 CREATE TABLE Department(
11     DepartmentID int IDENTITY(1,1) NOT NULL PRIMARY KEY,
12     Name NVARCHAR(200) NOT NULL,
13     GroupName NVARCHAR(200) NOT NULL,
14     Company NVARCHAR(300),
15     ModifiedDate datetime NOT NULL  DEFAULT (getdate())
16 )
17 
18 INSERT INTO Department(name,[Company],groupname) VALUES('销售部','中国你好有限公司XX分公司','销售组')
19 GO 100000
20 
21 CREATE TABLE DBCCResult (
22 PageFID NVARCHAR(200),
23 PagePID NVARCHAR(200),
24 IAMFID NVARCHAR(200),
25 IAMPID NVARCHAR(200),
26 ObjectID NVARCHAR(200),
27 IndexID NVARCHAR(200),
28 PartitionNumber NVARCHAR(200),
29 PartitionID NVARCHAR(200),
30 iam_chain_type NVARCHAR(200),
31 PageType NVARCHAR(200),
32 IndexLevel NVARCHAR(200),
33 NextPageFID NVARCHAR(200),
34 NextPagePID NVARCHAR(200),
35 PrevPageFID NVARCHAR(200),
36 PrevPagePID NVARCHAR(200)
37 )
38 
39 TRUNCATE TABLE [dbo].[DBCCResult]
40 
41 INSERT INTO DBCCResult EXEC ('DBCC IND(practice,Department,-1) ')
42 
43 SELECT * FROM [dbo].[DBCCResult] ORDER BY [PageType] DESC 
44 
45 DBCC TRACEON(3604,-1)
46 GO
47 DBCC PAGE(practice,1,114,3) 
48 GO
49 
50 select %%lockres%% AS '数据页的keyhashvalue' from Department
51 
52 
53 
54 
55 
56 
57 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
58 GO
59 BEGIN TRANSACTION
60 SELECT DepartmentID FROM Department WHERE DepartmentID BETWEEN 0 AND 122 
61 --COMMIT TRAN
62 
63 SELECT  resource_type ,
64         resource_database_id ,
65         resource_description ,
66         resource_associated_entity_id ,
67         request_mode ,
68         request_type ,
69         request_status
70 FROM    sys.dm_tran_locks
71 WHERE   [resource_database_id]=DB_ID('practice') 
72 AND [resource_description] LIKE '%b03b%'
73 ORDER BY [resource_type]
 1 --测试非聚集索引
 2 USE [testhashkey]
 3 GO
 4 CREATE TABLE testnoncluster
 5     (
 6       a NVARCHAR(3800) NOT NULL ,
 7       b INT NOT NULL
 8     )
 9 GO
10 
11 CREATE UNIQUE NONCLUSTERED INDEX ucil ON testnoncluster(b)
12 GO
13 
14 INSERT  testnoncluster
15 SELECT  CAST(11 AS VARCHAR(10))+replicate('a', 3500),1 UNION ALL
16 SELECT  CAST(22 AS VARCHAR(10))+replicate('a', 3500),2
17 
18 
19 SELECT * FROM [dbo].[testnoncluster]
 1 TRUNCATE TABLE [dbo].[DBCCResult]
 2 
 3 INSERT INTO DBCCResult EXEC ('DBCC IND(testhashkey,testnoncluster,-1) ')
 4 
 5 SELECT * FROM [dbo].[DBCCResult] ORDER BY [PageType] DESC 
 6 
 7 DBCC TRACEON(3604,-1)
 8 GO
 9 DBCC PAGE(testhashkey,1,77,3) 
10 GO
1 select %%lockres%% AS '数据页的keyhashvalue' from testnoncluster
 1 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
 2 GO
 3 BEGIN TRANSACTION
 4 SELECT b FROM [dbo].[testnoncluster] WHERE [b]=1
 5 --COMMIT TRAN
 6 
 7 SELECT  resource_type ,
 8         resource_database_id ,
 9         resource_description ,
10         resource_associated_entity_id ,
11         request_mode ,
12         request_type ,
13         request_status
14 FROM    sys.dm_tran_locks
15 WHERE   [resource_database_id]=DB_ID('testhashkey')
16 ORDER BY [resource_type]
 1 --测试堆表和非聚集索引表的数据页也有keyhashvalue
 2 USE [testhashkey]
 3 GO
 4 
 5 
 6 CREATE TABLE testnoncluster2
 7     (
 8       a NVARCHAR(3800) NOT NULL ,
 9       b INT NOT NULL,
10       c INT NOT NULL 
11     )
12 GO
13 
14 
15 
16 CREATE UNIQUE NONCLUSTERED INDEX ucil ON testnoncluster2(b)
17 GO
18 
19 INSERT  testnoncluster2
20 SELECT  CAST(11 AS VARCHAR(10))+replicate('a', 3500),1,1 UNION ALL
21 SELECT  CAST(22 AS VARCHAR(10))+replicate('a', 3500),2,2
22 
23 
24 
25 SET TRANSACTION ISOLATION LEVEL SERIALIZABLE
26 GO
27 BEGIN TRANSACTION
28 DELETE FROM [dbo].[testnoncluster2]  WHERE [c]=1
29 --ROLLBACK TRAN
30 
31 SELECT  resource_type ,
32         resource_database_id ,
33         resource_description ,
34         resource_associated_entity_id ,
35         request_mode ,
36         request_type ,
37         request_status
38 FROM    sys.dm_tran_locks
39 WHERE   [resource_database_id]=DB_ID('testhashkey') 
40 ORDER BY [resource_type]
41 
42 
43 
44 
45 select %%lockres%% AS '数据页的keyhashvalue' from testnoncluster2
 1 --测试堆表和非聚集索引表的数据页也有keyhashvalue
 2 USE [testhashkey]
 3 GO
 4 
 5 
 6 
 7 CREATE TABLE testnoncluster2
 8     (
 9       a NVARCHAR(3800) NOT NULL ,
10       b INT NOT NULL,
11       c INT NOT NULL 
12     )
13 GO
14 
15 
16 
17 CREATE UNIQUE NONCLUSTERED INDEX ucil ON testnoncluster2(b)
18 GO
19 
20 INSERT  testnoncluster2
21 SELECT  CAST(11 AS VARCHAR(10))+replicate('a', 3500),1,1 UNION ALL
22 SELECT  CAST(22 AS VARCHAR(10))+replicate('a', 3500),2,2
23 
24 
25 
26 
27 
28 TRUNCATE TABLE [dbo].[DBCCResult]
29 
30 INSERT INTO DBCCResult EXEC ('DBCC IND(testhashkey,testnoncluster2,-1) ')
31 
32 SELECT * FROM [dbo].[DBCCResult] ORDER BY [PageType] DESC 
33 
34 DBCC TRACEON(3604,-1)
35 GO
36 DBCC PAGE(testhashkey,1,165,3) 
37 GO

相关专题

更多
C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

3

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

7

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

30

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

2

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

8

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

3

2026.01.15

php图片上传教程汇总
php图片上传教程汇总

本专题整合了php图片上传相关教程,阅读专题下面的文章了解更多详细教程。

2

2026.01.15

phpstorm相关教程大全
phpstorm相关教程大全

本专题整合了phpstorm相关教程汇总,阅读专题下面的文章了解更多详细内容。

4

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.7万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.6万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号