校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > SqlServer 垂直分表(減少程序改動)

SqlServer 垂直分表(減少程序改動)

熱門標簽:在電子版地圖標注要收費嗎 武漢AI電銷機器人 外呼系統會封嗎 電銷機器人 深圳 地圖標注如何弄全套標 萬利達綜合醫院地圖標注點 股票配資電銷機器人 實體店地圖標注怎么標 南京電銷外呼系統哪家好

由于sqlserver的設計特殊性,一般大量數據一般都是采用水平分表,而垂直分表只是把text、圖片都較大數據放到單獨的表中,這樣數據設計會更合理,相對于mysql可能要好一點,mssql本來就是一個文件,基本上提升不大,目前來看幾十萬的數據沒有分不分表沒有任何影響,對于千萬以上數據還是采用水平分表比較好。

而 垂直分表 則相對很少見到和用到,因為這可能是數據庫設計上的問題了。如果數據庫中一張表有部分字段幾乎從不不更改但經常查詢,而部分字段的數據頻繁更改,這種設計放到同一個表中就不合理了,相互影響太大了。在已存在改情況的表的時候,可以考慮按列拆分表,即垂直拆分。

由于垂直分表的案例比較少,最近因為存在這樣的表,所以個人搗鼓了一下。

源表設計結構:

--  源表
CREATE TABLE [dbo].[DemoTab](
[Guid] [uniqueidentifier] NOT NULL,
[UserName] [nvarchar](30) NOT NULL,
[Password] [nvarchar](30) NOT NULL,
[UserAccount] [varchar](30) NOT NULL,
[Amount] [numeric](18, 4) NULL,
CONSTRAINT [PK_DemoTab] PRIMARY KEY CLUSTERED ([Guid])
)
GO
 
 
ALTER TABLE [dbo].[DemoTab] 
ADD CONSTRAINT [DF_DemoTab_Guid] DEFAULT (newsequentialid()) FOR [Guid]
GO
 
--  原來是訪問視圖的(好處就是視圖層不變)
CREATE VIEW [dbo].[VDemoTab]
AS
SELECT [Guid],[UserName],[Password],[UserAccount],[Amount]
FROM [dbo].[DemoTab]
GO

注:拆分后各表的主鍵都是相同了,而且拆分后的表是規范化的。

現在拆成兩張表:

注意選擇一張表作為基表,其他表都有與該表的外鍵。

--  分表【1】,以該表為"主表",其他拆分出的表為"子表"
CREATE TABLE [dbo].[DemoTab001](
[Guid] [uniqueidentifier] NOT NULL,
[UserName] [nvarchar](30) NOT NULL,
[Password] [nvarchar](30) NOT NULL,
CONSTRAINT [PK_DemoTab001] PRIMARY KEY CLUSTERED ([Guid])
)
GO
 
--  主鍵默認值可以不需要,因為插入數據前需要確定主鍵值
--ALTER TABLE [dbo].[DemoTab001] 
--ADD CONSTRAINT [DF_DemoTab001_Guid] DEFAULT (newsequentialid()) FOR [Guid]
--GO
 
--  分表【2】,"子表"
CREATE TABLE [dbo].[DemoTab002](
[Guid] [uniqueidentifier] NOT NULL,
[UserAccount] [varchar](30) NOT NULL,
[Amount] [numeric](18, 4) NULL,
CONSTRAINT [PK_DemoTab002] PRIMARY KEY CLUSTERED ([Guid])
)
GO
 
--  主鍵默認值可以不需要,因為插入數據前需要確定主鍵值
--ALTER TABLE [dbo].[DemoTab002] 
--ADD CONSTRAINT [DF_DemoTab002_Guid] DEFAULT (newsequentialid()) FOR [Guid]
--GO
 
 
--  若主表變更主鍵則級聯更新或刪除(主鍵通常是不更新的,也可省去 ON UPDATE CASCADE)
ALTER TABLE [dbo].[DemoTab002] 
ADD CONSTRAINT [FK_DemoTab002_DemoTab001_Guid] FOREIGN KEY ([Guid]) 
REFERENCES [DemoTab001]([Guid]) ON UPDATE CASCADE ON DELETE CASCADE
GO

如果之前是對單個表或者視圖操作,拆分之后邏輯層改動可能很多,為保持改動最小,可以用聯合視圖操作。怎么連接表依個人情況而定。

--  拆分后使用聯合視圖(INNER JOIN 也可以)
ALTER VIEW [dbo].[VDemoTab]
AS
SELECT T1.[Guid],T1.[UserName],T1.[Password],T2.[UserAccount],T2.[Amount]
FROM [dbo].[DemoTab001] T1 LEFT JOIN [dbo].[DemoTab002] T2 ON T1.[Guid]=T2.[Guid]
GO

這時問題來了,要對表進行DML操作,insert , update , delete 怎么解決?因為要求主鍵是分散在多個表并且是相同的!

這時只能用考慮觸發器來保證一致性了,觸發器則定義在視圖上,使用的是 INSTEAD OF 類型的觸發器。

insert 觸發器:

視圖 [VDemoTab] 中的 [Guid] 為表 插入時值,在插入觸發器中,虛擬表[inserted]的[Guid]是唯一的,所以在觸發器中可以同時使用該 [Guid] 插入到多個分表中,保證了多個分表的[Guid]是相同的!

--  insert 觸發器
CREATE TRIGGER [dbo].[tgr_VDemoTab_insert]
ON [dbo].[VDemoTab] 
INSTEAD OF INSERT
AS 
BEGIN
 INSERT INTO [dbo].[DemoTab001]([Guid],[UserName],[Password])
 SELECT [Guid],[UserName],[Password] FROM inserted;
 
 INSERT INTO [dbo].[DemoTab002]([Guid],[UserAccount],[Amount])
 SELECT [Guid],[UserAccount],[Amount] FROM inserted;
END
GO

update 觸發器:

同理,更新時涉及虛擬表 deleted 和 inserted,而更新是對視圖[VDemoTab]更新的,所以虛擬表inserted包括了所有的字段,所以需要觸發器分別更新多個分表。

--  update 觸發器
CREATE TRIGGER [dbo].[tgr_VDemoTab_update]  
ON [dbo].[VDemoTab]   
INSTEAD OF UPDATE  
AS
BEGIN
 UPDATE T1 SET 
 T1.[UserName] = T2.[UserName], 
 T1.[Password] = T2.[Password]
 FROM [dbo].[DemoTab001] AS T1, inserted AS T2 WHERE T1.[Guid] = T2.[Guid] 
 
 UPDATE T1 SET 
 T1.[UserAccount] = T2.[UserAccount], 
 T1.[Amount] = T2.[Amount]
 FROM [dbo].[DemoTab002] AS T1, inserted AS T2 WHERE T1.[Guid] = T2.[Guid] 
END
GO

delete 觸發器:

刪除視圖[VDemoTab]記錄,涉及多個表則不允許刪除,因此只要刪除"主表"的記錄即可,其他分表都會級聯刪除。

--  delete 觸發器
CREATE TRIGGER [dbo].[tgr_VDemoTab_delete]  
ON [dbo].[VDemoTab]   
INSTEAD OF DELETE  
AS
BEGIN
    DELETE FROM [dbo].[DemoTab001]
    WHERE [Guid] IN (SELECT [Guid] FROM deleted)
END
GO

設計基本就完成了,現在進行測試。

INSERT INTO [dbo].[VDemoTab]([Guid],[UserName],[Password],[UserAccount],[Amount])
SELECT NEWID(),'user01','pw01','account01',100
UNION ALL
SELECT NEWID(),'user02','pw02','account02',99
UNION ALL
SELECT NEWID(),'user03','pw03','account03',0
GO
 
UPDATE [VDemoTab] SET [Password]='pw',[Amount]='10'
WHERE [Amount] >=0 AND [Amount]100 AND [UserName] LIKE '%3'
GO
 
DELETE FROM [VDemoTab] WHERE [UserName] = 'user03'
GO
 
SELECT * FROM [dbo].[DemoTab001] 
SELECT * FROM [dbo].[DemoTab002] 
SELECT * FROM [dbo].[VDemoTab]

基本操作都是正常的!垂直分表完成!

性能怎么樣呢?

由于 Guid 作為主鍵,使用的是 NEWID() 而不是  NEWSEQUENTIALID(),新增記錄時聚集索引都可能重新排序較多數據。

分表之后,單個數據頁能存儲的數據更多了,但是分成多個表中,數據頁也增多了,同時 Guid 在每個表都存在,所以查詢數據時IO會更多。

對于更新數據,在觸發器中是兩個表同時更新的,即使更新其中一個分表,其他分表都會影響。如果分表之后不同時更新,可以在觸發器中使用 if(update(col)) 來判斷更新的是那一列,就更新相應的基表就行,其他分表不更新。

最好的情況就是,拆分后的表都是“獨立”的,不用聯合視圖,查詢和更改都獨立,這需要更改邏輯層。

到此這篇關于SqlServer 垂直分表(減少程序改動)的文章就介紹到這了,更多相關SqlServer 垂直分表內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • sqlserver2017共享功能目錄路徑不可改的解決方法
  • SQLServer2008提示評估期已過解決方案
  • SQLServer2019 數據庫的基本使用之圖形化界面操作的實現
  • SQLServer2019 數據庫環境搭建與使用的實現
  • SQLServer 日期函數大全(小結)
  • SQLServer2019配置端口號的實現
  • sqlserver主鍵自增的實現示例
  • C語言中操作sqlserver數據庫案例教程

標簽:武威 泰安 濟寧 安徽 汕頭 廣東 臺州 濟源

巨人網絡通訊聲明:本文標題《SqlServer 垂直分表(減少程序改動)》,本文關鍵詞  SqlServer,垂直,分表,減少,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SqlServer 垂直分表(減少程序改動)》相關的同類信息!
  • 本頁收集關于SqlServer 垂直分表(減少程序改動)的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲少妇最新在线视频| 国产91色综合久久免费分享| 中文字幕欧美区| 久久久久久亚洲综合| 久久久久久久久岛国免费| 久久精品在线观看| 亚洲超碰97人人做人人爱| 日韩精品色哟哟| 成熟亚洲日本毛茸茸凸凹| 成人精品免费看| 日韩欧美一二三| 亚洲免费观看高清完整版在线 | 欧美成人r级一区二区三区| 在线播放91灌醉迷j高跟美女| 91麻豆精品国产无毒不卡在线观看| 久久精品夜色噜噜亚洲a∨| 又紧又大又爽精品一区二区| 国产成人av电影在线播放| 欧美一区二区三区男人的天堂| 国产欧美日韩三区| 视频一区视频二区中文字幕| 成人免费毛片片v| 欧美刺激脚交jootjob| 日韩国产精品91| 99v久久综合狠狠综合久久| 亚洲电影中文字幕在线观看| 视频一区欧美日韩| 日本免费在线视频不卡一不卡二| 一区二区免费在线播放| 三级欧美韩日大片在线看| 久草这里只有精品视频| 老色鬼精品视频在线观看播放| 国产人伦精品一区二区| 中文字幕亚洲一区二区av在线| 亚洲成人av中文| 国产成人日日夜夜| 日韩精品专区在线影院重磅| 欧美一区二区免费| 日韩激情一二三区| 韩国女主播一区二区三区| 国产成人av电影免费在线观看| 99精品黄色片免费大全| 成人app网站| 亚洲精品美国一| 国产91精品精华液一区二区三区| 成人av电影在线播放| 欧美一区二区三区免费观看视频| 亚洲男同性恋视频| 欧美亚洲国产一区在线观看网站| 欧美高清在线精品一区| 三级亚洲高清视频| 欧美大片在线观看一区| 精品无人码麻豆乱码1区2区 | 亚洲一区二区精品3399| 日韩一区二区在线观看| 成人免费视频caoporn| 亚洲国产精品久久人人爱蜜臀| 中文字幕第一区综合| 在线免费观看成人短视频| 国产99久久久国产精品潘金 | 亚洲一区免费观看| 国产欧美一区二区精品仙草咪| 欧美日韩视频在线第一区| av综合在线播放| 国产99精品视频| 国产v日产∨综合v精品视频| 麻豆一区二区三区| 美美哒免费高清在线观看视频一区二区| 国产欧美日韩精品a在线观看| 日韩美女主播在线视频一区二区三区| 欧美日韩免费观看一区三区| 日本高清成人免费播放| 色狠狠一区二区三区香蕉| 一本到高清视频免费精品| 一本到不卡免费一区二区| 在线观看一区二区视频| 欧美性猛交一区二区三区精品| 色老汉av一区二区三区| 欧美精品一卡二卡| 国产三级一区二区| 国产精品久久国产精麻豆99网站| 国产精品激情偷乱一区二区∴| 国产精品国产三级国产普通话99 | 成人精品视频.| 欧美日韩一区视频| 欧美国产日韩在线观看| 亚洲欧美另类小说视频| 视频一区二区中文字幕| 成人av动漫网站| 欧美日韩国产综合久久| 国产午夜精品一区二区| 日韩激情一区二区| 色综合久久久久久久久| 日韩免费性生活视频播放| 综合色中文字幕| 国产一区二区三区视频在线播放| 91在线看国产| 精品sm在线观看| 黄色日韩网站视频| 欧美日韩不卡一区| 午夜亚洲国产au精品一区二区| 丁香五精品蜜臀久久久久99网站 | 欧美三片在线视频观看 | 欧美日韩精品一区二区三区蜜桃 | 欧洲一区二区av| 国产精品久久网站| jiyouzz国产精品久久| 国产欧美一区二区三区鸳鸯浴| 日韩有码一区二区三区| 91精品在线免费| 亚洲va欧美va人人爽| 欧美性极品少妇| 日韩av电影一区| 精品sm在线观看| 国产成人8x视频一区二区| 一区在线观看视频| 欧美日韩国产精品自在自线| 日韩二区三区在线观看| 国产性天天综合网| 欧美性欧美巨大黑白大战| 午夜精品久久久久| 精品久久久网站| 色噜噜偷拍精品综合在线| 日韩av在线免费观看不卡| 久久久久青草大香线综合精品| 国产乱子轮精品视频| 亚洲私人黄色宅男| 久久久www成人免费毛片麻豆| 色综合咪咪久久| 国产精品一区在线观看你懂的| 日韩码欧中文字| 国产亚洲一本大道中文在线| 欧美艳星brazzers| 不卡的av电影| 国内久久婷婷综合| 日韩成人dvd| 亚洲成人av在线电影| 国产精品初高中害羞小美女文| 欧美日韩一区二区在线观看| 成人av网站免费观看| 精品一区二区三区视频在线观看 | 亚洲最色的网站| 国产精品私人自拍| 久久久噜噜噜久久人人看| 777a∨成人精品桃花网| 777xxx欧美| 91精品国产91久久久久久最新毛片| 99在线精品观看| 99re热这里只有精品免费视频 | 久久久久97国产精华液好用吗| 欧美军同video69gay| 欧美日韩一级二级三级| 91国偷自产一区二区三区观看| 国产一区二区不卡老阿姨| 国内成人精品2018免费看| 美女尤物国产一区| 岛国一区二区在线观看| 99在线精品免费| 5858s免费视频成人| 欧美成人r级一区二区三区| 久久综合狠狠综合久久综合88| 国产aⅴ综合色| a级精品国产片在线观看| 欧美日韩免费一区二区三区视频| 欧美高清激情brazzers| 久久综合久久综合九色| 亚洲国产电影在线观看| 一区二区三区资源| 麻豆精品一区二区av白丝在线| 国产suv精品一区二区三区| 欧美亚洲国产bt| 国产女主播一区| 三级精品在线观看| 91精品福利视频| 亚洲欧美成人一区二区三区| 久久99蜜桃精品| 欧美日韩国产高清一区二区 | 欧美国产日韩亚洲一区| 美女脱光内衣内裤视频久久网站| gogo大胆日本视频一区| 欧美mv和日韩mv的网站| 日韩在线一二三区| 欧美日韩在线播| 三级不卡在线观看| 欧美日本免费一区二区三区| 亚洲欧洲日本在线| 91一区二区三区在线播放| 国产精品久久三| 波多野结衣视频一区| 中文一区二区完整视频在线观看| 国产一区二区日韩精品| 久久午夜电影网| 高清日韩电视剧大全免费| 国产视频在线观看一区二区三区| 国产激情视频一区二区三区欧美 | 亚洲欧美日韩人成在线播放| 91麻豆自制传媒国产之光| 亚洲视频一区二区免费在线观看| www.成人在线| 日韩av电影免费观看高清完整版 |