亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

【Paddy】如何將物理表分割成動態數據表與靜態數據表

2024-07-21 02:47:15
字體:
來源:轉載
供稿:網友
【Paddy】如何將物理表分割成動態數據表與靜態數據表

前言  

  一般來說,物理表的增、刪、改、查都受到數據量的制約,進而影響了性能。

  很多情況下,你所負責的業務關鍵表中,每日變動的數據庫與不變動的數據量比較,相差非常大。

  這里我們將變動的數據稱為動態數據,不變動的數據稱為靜態數據。

  舉個例子,1張1000W的表,每日動態數據只有1W條,999W條的數據都為靜態。往往select或者重復改變的數據都在動態數據中。比如訂單表。

  所以,如果將動態數據庫從表中剝離出來,分割兩張表,一張動態數據表,一張靜態數據表,從數據量的角度來看,性能是不是就會自然提高了?

  下圖為一張現實表和一張理想化的結構(藍色為靜態數據:1000W、黃色為動態數據:100W):

  

  希望動態數據和靜態數據分割開

  

  

  想法再好,也比不上現實的殘酷。很多朋友可能都想到這種架構,但實現起來問題非常多:

  

  1.  如何將動態數據自動從靜態數據中剝離?如何維護?

  2.  程序代碼改動量不可預計。尤其核心表的使用遍布各地,分割成兩張表后,所有代碼基本都要重構。

  3.  表分區是否可以達到同樣目的,NO~因為表分區無法100%區分動態與靜態,而且分區列的使用決定了效率。

  下面開始,進入本次主題,如何在SQL Server中達到動態數據、靜態數據分割;兩表數據如何自動維護;程序統一訪問邏輯表名,零維護成本。

正文

 實現方法:利用視圖 + 視圖觸發器

  沒錯,沒有了~就是靠這兩貨,就解決了,下面我們來看看邏輯圖(畫的不好,見諒)。

  

最后,讓我們來看看具體事例

1.  創建demo數據庫,和動態表(TB_A_NEW)、歷史表(TB_A_OLD)

CREATE DATABASE demoGOALTER DATABASE demo ADD FILEGROUP HekatonFG CONTAINS MEMORY_OPTIMIZED_DATA;GOALTER DATABASE demo ADD FILE( NAME = 'Memory', FILENAME ='C:/Memory.ndf') TO FILEGROUP [HekatonFG];GOCREATE TABLE TB_A_OLD(id INT IDENTITY(1,1) PRIMARY KEY,     NAME NVARCHAR(36)GOCREATE TABLE TB_A_NEW  (     id   INT IDENTITY(1, 1) PRIMARY KEY,     NAME NVARCHAR(36)  )GOINSERT INTO TB_A_OLDSELECT Newid()GO 10

這個時候的兩張表的數據如下:

然后,我們為了保證動態表的新增數據的自增值是靜態表的當前標識值+1,這樣兩表記錄合并才能銜接。

DECLARE @IDENT BIGINTSELECT @IDENT = Ident_current('TB_A_OLD') + 1DBCC checkident('TB_A_NEW', reseed, @IDENT)

  

創建視圖(View_TB_A)

CREATE VIEW [dbo].[View_TB_A]AS  SELECT *  FROM   TB_A_NEW  UNION ALL  SELECT old.*  FROM   TB_A_OLD old         LEFT JOIN TB_A_NEW new                ON old.id = new.id  WHERE  new.NAME IS NULLGO

創建視圖觸發器(Insert、Update)

USE demoGOCREATE TRIGGER [dbo].[TR_Insert]ON [dbo].[View_TB_A]INSTEAD OF INSERTAS  BEGIN      SET NOCOUNT ON      INSERT INTO TB_A_NEW                  (NAME)      SELECT NAME      FROM   inserted  ENDGOUSE demoGOCREATE TRIGGER [dbo].[TR_Update]ON [dbo].[View_TB_A]INSTEAD OF UPDATEAS  BEGIN      SET NOCOUNT ON      --1. 判斷update中,包含的記錄是否都在new表中      DECLARE @count BIGINT      SELECT @count = Count(1)      FROM   deleted      UPDATE TB_A_NEW      SET    NAME = b.NAME      FROM   TB_A_NEW a,             inserted b      WHERE  a.id = b.id      IF @@ROWCOUNT < @count        BEGIN            SET IDENTITY_INSERT TB_A_NEW ON            INSERT INTO TB_A_NEW                        (id,                         NAME)            SELECT i.id,                   i.NAME            FROM   inserted i                   LEFT JOIN TB_A_NEW n                          ON i.id = n.id            WHERE  n.NAME IS NULL        END  ENDGO

下面,我們來測試下SELECT、UPDATE、INSERT

Select

SELECT的結果就是剛才的插入10條記錄,通過!

Insert

INSERT到視圖中,會在TB_A_NEW表中新增一條記錄,TB_A_OLD并沒有任何變化。也就是自動分配到了動態表中,通過!

Update

然后我們繼續更新id=2的記錄,看看結果如何

最后,我們繼續查詢視圖VIEW_TB_A,看看最終返回的結果。

看到最終結果11條,并且之前通過視圖的更新,插入都返回了正確結果,通過!

至此,測試結束,通過視圖和視圖觸發器,實現了統一名稱訪問,底冊物理表分割動態表和靜態表,測試過程并不包含delete,感興趣的童鞋稍微琢磨下就出來了。

如果需要合并動態表與靜態表,只需將id相同記錄,更新到靜態表,靜態表不存在的id對應動態數據,插入到靜態表中即可。

本次內容主意在實現方法,具體性能提升測試,日后再做說明,簡單說下,就是觸發器的邏輯處理,放在了物理表插入數據之前。將數據分類存儲。所以邏輯處理開銷會增加,但是物理存儲分割。在數據量影響性能明顯的場景中會非常適用。

如果你的數據庫是SQL Server 2014,那么將靜態和動態表定義到內存表中,動態數據又剝離了,具體提升多少這里不做猜測,有環境的朋友可以試試哦~

另:

  利用以上方法,也可以解決肖桑(大菠蘿)和笑東風提到的的主鍵int修改為bigint型問題

 ?。╤ttp://www.cnblogs.com/TeyGao/p/4463389.html)

如果每日一次合并動態表與靜態表數據,動態數據表就是當日的差異數據哦,擴展使用非常方便。

好~就到這里,再見吧~


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美午夜精品久久久久久人妖| 久久影视电视剧凤归四时歌| 日韩av电影在线免费播放| 亚洲精品一区中文| 亚洲福利在线看| 亚洲美女自拍视频| 亚洲精品国精品久久99热| 亚洲人成电影网站色xx| 亚洲国产美女精品久久久久∴| 亚洲欧美在线一区二区| 国产精品成人播放| 成人女保姆的销魂服务| 欧美电影免费在线观看| 亚洲美女在线看| 亚洲小视频在线| 日韩成人激情影院| 伊人伊成久久人综合网小说| 欧美性猛交xxxx富婆| 国产精品久久久久7777婷婷| 国产成人精品一区二区在线| 日本在线观看天堂男亚洲| 国产精品扒开腿做爽爽爽男男| 欧美xxxx18国产| 成人av番号网| 久久久久久久久久久免费精品| 国产一区二区日韩| 国产99久久精品一区二区永久免费| 国内精品久久久久影院 日本资源| 97在线视频免费观看| 国产精品久久久久77777| 亚洲精品网址在线观看| 久久精品成人欧美大片| 亚洲天堂男人的天堂| 欧美另类69精品久久久久9999| 欧美夫妻性生活视频| 欧美激情影音先锋| 欧美精品www| 精品少妇一区二区30p| 国产成人av网址| 国产91色在线播放| 一区二区三区视频观看| 国产成人精品视| 国产日韩欧美中文在线播放| 在线观看日韩av| 91情侣偷在线精品国产| xxav国产精品美女主播| 国产精品免费久久久久久| 日本不卡高字幕在线2019| 国产精品麻豆va在线播放| 亚洲欧美国产精品专区久久| 最新国产成人av网站网址麻豆| 日本一区二区三区在线播放| 欧美成人sm免费视频| 精品久久久av| 97国产精品人人爽人人做| 日韩中文在线观看| 亚洲一区中文字幕在线观看| 久久不射电影网| 成人午夜激情免费视频| 国产精品视频中文字幕91| 日韩电影免费在线观看| 欧美日产国产成人免费图片| 欧美激情精品久久久久久| 久久91亚洲精品中文字幕奶水| 国产精品久久久久久av下载红粉| 久久久精品亚洲| 亚洲国产一区二区三区在线观看| 精品久久久久久中文字幕一区奶水| 亚洲天堂久久av| 亚洲综合中文字幕在线| 欧美理论片在线观看| 日韩在线播放av| 国产日韩换脸av一区在线观看| 亚洲国产女人aaa毛片在线| 狠狠色噜噜狠狠狠狠97| 久久久之久亚州精品露出| 久久国产精彩视频| 国产精品99久久久久久久久久久久| 欧美精品久久久久久久久| 在线观看国产成人av片| 日韩欧美精品在线观看| www.日韩av.com| 亚洲美女自拍视频| 久久成人亚洲精品| 国产精品久久一区主播| 欧美限制级电影在线观看| 红桃视频成人在线观看| 欧美日韩国产综合视频在线观看中文| 久久久影视精品| 国产91|九色| 色狠狠av一区二区三区香蕉蜜桃| 8050国产精品久久久久久| 国产成人精品av在线| 日韩成人久久久| 欧美高跟鞋交xxxxxhd| 黄色成人av在线| 精品久久久久久国产91| 国产亚洲精品美女| 一区二区三区精品99久久| 操人视频在线观看欧美| 色一区av在线| 欧美成人免费网| 成人av色在线观看| 精品精品国产国产自在线| 色综合五月天导航| 国内精品久久久久影院优| 欧美壮男野外gaytube| 亚洲欧美国产精品va在线观看| 精品在线观看国产| 国产做受高潮69| 人妖精品videosex性欧美| 欧美性感美女h网站在线观看免费| 国产精品国语对白| 91精品久久久久久久久中文字幕| 91免费综合在线| 国产视频精品久久久| 国产精品视频最多的网站| 色哟哟亚洲精品一区二区| 亚洲自拍小视频| 2019国产精品自在线拍国产不卡| 国产精品欧美风情| 亚洲变态欧美另类捆绑| 91精品久久久久久久| 亚洲一区二区三区在线免费观看| 亚洲人精选亚洲人成在线| 九色精品免费永久在线| 国产成人免费91av在线| 国产精品久久久久av免费| 欧美在线一区二区三区四| 少妇久久久久久| 亚洲国产精品va在看黑人| 欧美性猛交xxxx乱大交| 国产精品第一页在线| 欧美精品videosex极品1| 毛片精品免费在线观看| 久久精品中文字幕| 亚洲色图35p| 久久久久久久香蕉网| 亚洲韩国欧洲国产日产av| 亚洲第一精品夜夜躁人人爽| 91精品国产自产在线老师啪| 91精品久久久久| 大桥未久av一区二区三区| 欧美在线日韩在线| 91久久在线播放| 国产精品白嫩初高中害羞小美女| 92国产精品视频| 97视频人免费观看| 亚洲国产精品久久精品怡红院| 亚洲国产成人久久| 国内精品视频一区| 亚洲欧洲成视频免费观看| 欧美激情亚洲国产| 青青久久aⅴ北条麻妃| 成人久久久久久久| 久久久国产在线视频| 日韩欧美国产黄色| 精品呦交小u女在线| 国产亚洲精品久久久久久777| 国产主播在线一区| 中文字幕亚洲欧美日韩高清| 国产成人精品电影久久久| 在线观看中文字幕亚洲| 在线免费观看羞羞视频一区二区|