日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
SQLServer表分區(qū)的NULL值問題

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

成都創(chuàng)新互聯(lián)公司-云計算及IDC服務(wù)提供商,涵蓋公有云、IDC機房租用、雅安電信機房、等保安全、私有云建設(shè)等企業(yè)級互聯(lián)網(wǎng)基礎(chǔ)服務(wù),溝通電話:13518219792

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

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

  這次我們測試SQL Server表分區(qū)的分區(qū)列的NULL值,究竟NULL值是被存放在哪個區(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(INT) AS 
  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.name) AS partition_scheme , 
  3.         p.partition_number , 
  4.         CONVERT(VARCHAR(MAX), ds2.name) AS 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ū)編號] 

  

  第二個視圖直接把NULL值忽略了

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

  

  分析一下

  

  總結(jié)

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


分享名稱:SQLServer表分區(qū)的NULL值問題
文章起源:http://www.5511xx.com/article/cdcsdig.html