自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SQL Server表分區(qū)的NULL值問題

數(shù)據(jù)庫 SQL Server
SQL Server表分區(qū)只支持range分區(qū)這一種類型,往往會(huì)被大家吐槽 人家MySQL支持四種類型:RANGE分區(qū)、LIST分區(qū)、HASH分區(qū)、KEY分區(qū)。

  SQL Server表分區(qū)只支持range分區(qū)這一種類型,往往會(huì)被大家吐槽

  人家MySQL支持四種類型:RANGE分區(qū)、LIST分區(qū)、HASH分區(qū)、KEY分區(qū)

  共同點(diǎn)是MySQL跟SQL Server也有分區(qū)對齊的問題,都是水平切分,大家都允許分區(qū)列存在NULL值

  這次我們測試SQL Server表分區(qū)的分區(qū)列的NULL值,究竟NULL值是被存放在哪個(gè)區(qū)間,以前一直沒有注意

  測試腳本

 

  1. --1.創(chuàng)建文件組 
  2. ALTER DATABASE [sss] 
  3. ADD FILEGROUP [FG_TinyBlog_Id_01] 
  4.  
  5. ALTER DATABASE [sss] 
  6. ADD FILEGROUP [FG_TinyBlog_Id_02] 
  7.  
  8. ALTER DATABASE [sss] 
  9. ADD FILEGROUP [FG_TinyBlog_Id_03] 
  10.  
  11. ALTER DATABASE [sss] 
  12. ADD FILEGROUP [FG_TinyBlog_Id_04] 
  13.  
  14. ALTER DATABASE [sss] 
  15. ADD FILEGROUP [FG_TinyBlog_Id_05] 
  16.  
  17.  
  18. --2.創(chuàng)建文件 
  19. ALTER DATABASE [sss] 
  20. ADD FILE 
  21. (NAME = N'FG_TinyBlog_Id_01_data',FILENAME = N'E:\DataBase\sss\FG_TinyBlog_Id_01_data.ndf',SIZE = 96MB, FILEGROWTH = 24MB ) 
  22. TO FILEGROUP [FG_TinyBlog_Id_01]; 
  23.  
  24. ALTER DATABASE [sss] 
  25. ADD FILE 
  26. (NAME = N'FG_TinyBlog_Id_02_data',FILENAME = N'E:\DataBase\sss\FG_TinyBlog_Id_02_data.ndf',SIZE = 96MB, FILEGROWTH = 24MB ) 
  27. TO FILEGROUP [FG_TinyBlog_Id_02]; 
  28.  
  29. ALTER DATABASE [sss] 
  30. ADD FILE 
  31. (NAME = N'FG_TinyBlog_Id_03_data',FILENAME = N'E:\DataBase\sss\FG_TinyBlog_Id_03_data.ndf',SIZE = 96MB, FILEGROWTH = 24MB ) 
  32. TO FILEGROUP [FG_TinyBlog_Id_03]; 
  33.  
  34. ALTER DATABASE [sss] 
  35. ADD FILE 
  36. (NAME = N'FG_TinyBlog_Id_04_data',FILENAME = N'E:\DataBase\sss\FG_TinyBlog_Id_04_data.ndf',SIZE = 96MB, FILEGROWTH = 24MB ) 
  37. TO FILEGROUP [FG_TinyBlog_Id_04]; 
  38.  
  39. ALTER DATABASE [sss] 
  40. ADD FILE 
  41. (NAME = N'FG_TinyBlog_Id_05_data',FILENAME = N'E:\DataBase\sss\FG_TinyBlog_Id_05_data.ndf',SIZE = 96MB, FILEGROWTH = 24MB ) 
  42. TO FILEGROUP [FG_TinyBlog_Id_05]; 
  43.  
  44.  
  45. --3.創(chuàng)建分區(qū)函數(shù) 
  46. CREATE PARTITION FUNCTION 
  47. Fun_TinyBlog_Id(INTAS 
  48. RANGE LEFT 
  49. FOR VALUES(-10,0,1,6) 
  50.  
  51.  
  52. --4.創(chuàng)建分區(qū)方案 
  53. CREATE PARTITION SCHEME 
  54. [Sch_TinyBlog_Id] AS 
  55. PARTITION [Fun_TinyBlog_Id] 
  56. TO([FG_TinyBlog_Id_01],[FG_TinyBlog_Id_02],[FG_TinyBlog_Id_03],[FG_TinyBlog_Id_04],[FG_TinyBlog_Id_05]) 

 

  插入測試數(shù)據(jù)

 

  1. USE [sss] 
  2.  
  3.  
  4.  
  5. CREATE TABLE TinyBlog(id INT  NULL,NAME VARCHAR(100))  
  6.  ON [Sch_TinyBlog_Id](id) 
  7.  
  8.  
  9.  
  10.  
  11. SELECT * FROM TinyBlog ORDER BY id  
  12.  
  13.  
  14. INSERT INTO [dbo].[TinyBlog] 
  15.         ( [id], [NAME] ) 
  16. VALUES  ( NULL-- id - int 
  17.           '3232'  -- NAME - varchar(100) 
  18.           ) 
  19.  
  20. INSERT INTO [dbo].[TinyBlog] 
  21.         ( [id], [NAME] ) 
  22. VALUES  ( -2, -- id - int 
  23.           '-2'  -- NAME - varchar(100) 
  24.           ) 
  25.  
  26.  
  27. INSERT INTO [dbo].[TinyBlog] 
  28.         ( [id], [NAME] ) 
  29. VALUES  ( 66, -- id - int 
  30.           '66'  -- NAME - varchar(100) 
  31.           ) 
  32.  
  33. INSERT INTO [dbo].[TinyBlog] 
  34.         ( [id], [NAME] ) 
  35. VALUES  ( 0, -- id - int 
  36.           '0'  -- NAME - varchar(100) 
  37.           ) 
  38.  
  39. INSERT INTO [dbo].[TinyBlog] 
  40.         ( [id], [NAME] ) 
  41. VALUES  ( -30, -- id - int 
  42.           '-30'  -- NAME - varchar(100) 
  43.           ) 

 

  表數(shù)據(jù)如下

 

  1. SELECT * FROM TinyBlog ORDER BY id  

  

 分區(qū)分布 

  1. --查看分區(qū)架構(gòu)文件組分布 
  2. SELECT  CONVERT(VARCHAR(MAX), ps.nameAS partition_scheme , 
  3.         p.partition_number , 
  4.         CONVERT(VARCHAR(MAX), ds2.nameAS filegroup , 
  5.         CONVERT(VARCHAR(MAX), ISNULL(v.value, ''), 120) AS range_boundary , 
  6.         STR(p.rows, 9) AS rows 
  7. FROM    sys.indexes i 
  8.         JOIN sys.partition_schemes ps ON i.data_space_id = ps.data_space_id 
  9.         JOIN sys.destination_data_spaces dds ON ps.data_space_id = dds.partition_scheme_id 
  10.         JOIN sys.data_spaces ds2 ON dds.data_space_id = ds2.data_space_id 
  11.         JOIN sys.partitions p ON dds.destination_id = p.partition_number 
  12.                                  AND p.object_id = i.object_id 
  13.                                  AND p.index_id = i.index_id 
  14.         JOIN sys.partition_functions pf ON ps.function_id = pf.function_id 
  15.         LEFT JOIN sys.Partition_Range_values v ON pf.function_id = v.function_id 
  16.                                                   AND v.boundary_id = p.partition_number 
  17.                                                   - pf.boundary_value_on_right 
  18. WHERE   i.object_id = OBJECT_ID('TinyBlog'
  19.         AND i.index_id IN ( 0, 1 ) 
  20. ORDER BY p.partition_number 
  21.  
  22.  
  23. --分區(qū)區(qū)間 
  24. --SELECT  *  FROM    sys.partition_range_values 

 


 分區(qū)情況  

  1. --分區(qū)情況 
  2. SELECT  c.* , 
  3.         b.[groupname] AS '分區(qū)方案對應(yīng)的文件組名稱' , 
  4.         d.name '當(dāng)前分區(qū)函數(shù)對應(yīng)的分區(qū)方案' 
  5. FROM    sys.destination_data_spaces AS a 
  6.         INNER JOIN sysfilegroups AS b ON a.[data_space_id] = b.[groupid] 
  7.         INNER JOIN ( SELECT $PARTITION.Fun_TinyBlog_Id(id) AS 分區(qū)編號 , 
  8.                             MIN(id) AS Min_value , 
  9.                             MAX(id) AS Max_value , 
  10.                             COUNT(id) AS 記錄數(shù) 
  11.                      FROM   [dbo].[TinyBlog] 
  12.                      GROUP BY $PARTITION.Fun_TinyBlog_Id(id) 
  13.                    ) AS c ON c.[分區(qū)編號] = a.[destination_id] 
  14.         INNER JOIN sys.partition_schemes AS d ON a.[partition_scheme_id] = d.data_space_id 
  15. ORDER BY c.[分區(qū)編號] 

  

 

  第二個(gè)視圖直接把NULL值忽略了

  根據(jù)***個(gè)視圖,我們畫出一個(gè)總結(jié)圖

  

 

  分析一下

  

 

  總結(jié)

  結(jié)論其實(shí)很清晰,分區(qū)列不要允許NULL,如果允許列,那么我們交換分區(qū)歸檔數(shù)據(jù)的時(shí)候就會(huì)有麻煩了,因?yàn)闊o法判斷分區(qū)列是NULL值的那些數(shù)據(jù)行是老數(shù)據(jù)還是新數(shù)據(jù)。

責(zé)任編輯:honglu 來源: 博客園
相關(guān)推薦

2010-11-10 14:47:11

SQL Server創(chuàng)

2021-01-18 05:23:14

SQL 排序Server

2010-07-19 11:01:55

SQL Server

2010-09-28 11:48:36

SQL NULL值

2011-07-20 16:03:06

SQL Server數(shù)分區(qū)表

2010-09-10 13:37:30

表分區(qū)SQL Server

2010-09-13 11:09:34

SQL SERVER分

2011-04-13 14:20:52

SQL Server主鍵

2010-09-16 14:38:55

Sql server表

2010-09-16 15:25:46

SqlServer20

2010-09-16 16:06:01

sql server表

2010-07-13 12:26:49

SQL Server

2010-11-10 14:35:17

SQL Server創(chuàng)

2010-07-22 16:02:29

2010-07-23 14:11:18

SQL Server

2010-10-19 16:40:34

sql server掛

2011-04-18 10:13:15

SQL Server 自動(dòng)化表分區(qū)

2010-09-16 14:13:11

SQL Server系

2010-07-26 14:09:32

SQL Server

2010-09-14 11:36:37

SQL Server系
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號