時(shí)間:2024-02-04 13:45作者:下載吧人氣:17
由于sqlserver的設(shè)計(jì)特殊性,一般大量數(shù)據(jù)一般都是采用水平分表,而垂直分表只是把text、圖片都較大數(shù)據(jù)放到單獨(dú)的表中,這樣數(shù)據(jù)設(shè)計(jì)會(huì)更合理,相對(duì)于mysql可能要好一點(diǎn),mssql本來就是一個(gè)文件,基本上提升不大,目前來看幾十萬的數(shù)據(jù)沒有分不分表沒有任何影響,對(duì)于千萬以上數(shù)據(jù)還是采用水平分表比較好。
而 垂直分表 則相對(duì)很少見到和用到,因?yàn)檫@可能是數(shù)據(jù)庫設(shè)計(jì)上的問題了。如果數(shù)據(jù)庫中一張表有部分字段幾乎從不不更改但經(jīng)常查詢,而部分字段的數(shù)據(jù)頻繁更改,這種設(shè)計(jì)放到同一個(gè)表中就不合理了,相互影響太大了。在已存在改情況的表的時(shí)候,可以考慮按列拆分表,即垂直拆分。
由于垂直分表的案例比較少,最近因?yàn)榇嬖谶@樣的表,所以個(gè)人搗鼓了一下。
源表設(shè)計(jì)結(jié)構(gòu):
— 源表
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
網(wǎng)友評(píng)論