SQL Server – 基本操作 Table 和 Column

前言

日常都是用 EF Core 來管理 Database, 偶爾也用 Management Studio, 就是很少手寫 Command. 雖然網上一拉就有很多, 但是每次寫單側都要到處找還是挺煩的.

所以決定寫一篇來記入起來.

 

創建 Table

GO
CREATE TABLE [Product] (
    [Id] int NOT NULL IDENTITY,
    [Name] nvarchar(256) NOT NULL DEFAULT '',
    [InStock] bit NOT NULL DEFAULT 0,
    [Price] decimal(19,2) NOT NULL DEFAULT 0,
    CONSTRAINT [PK_Product] PRIMARY KEY NONCLUSTERED ([Id])
);
CREATE UNIQUE CLUSTERED INDEX [IX_Product_Name] ON [Product] ([Name] ASC);
GO

裏面涉及到了幾個點

1. identity 是 auto increment

2. column name | type | nullable | default value

3. 通常 Id 都是 primary key, 但是 nonclustered 或 clustered 就不一定

4. 如果有 nature key, 那麼通常它是 unique + clustered

 

創建 Column

ALTER TABLE [Product] ADD [NewColumn] nvarchar(256) NOT NULL DEFAULT '';

 

創建 Computed Column

ALTER TABLE [Product] ADD FullName AS ([FirstName] + ' ' + [LastName]) PERSISTED;

PERSISTED 是永久, 可以做索引

 

創建 Index

CREATE UNIQUE CLUSTERED INDEX [IX_TableName_Column1Name_Column2Name] ON [Product] ([Column1], [Column1] DESC);

 

創建 ForeignKey

GO
 CREATE TABLE [Color] (
    [Id] int NOT NULL IDENTITY,
    [ProductId] int NOT NULL,
    [Name] nvarchar(450) NOT NULL,
    CONSTRAINT [PK_Color] PRIMARY KEY NONCLUSTERED ([Id]),
    CONSTRAINT [FK_Color_Product_ProductId] FOREIGN KEY ([ProductId]) REFERENCES [Product] ([Id]) ON DELETE CASCADE);

    CREATE UNIQUE CLUSTERED INDEX [IX_Color_ProductId_Name] ON [Color] ([ProductId], [Name]);
GO
View Code

或者

ALTER TABLE [Color] ADD CONSTRAINT [FK_Color_Product_ProductId] FOREIGN KEY ([ProductId]) REFERENCES [Product] ([Id]) ON DELETE CASCADE;

on delete 有 NO ACTION | CASCADE | SET NULL

 

Edit Column Type

ALTER TABLE [Product] ALTER COLUMN [Name] nvarchar(max);

 

Rename

rename table 和 column 是很恐怖的操作. 因爲 index, foreign key 都會用 table name 和 column name 命名. 所以它需要批量換

EXEC sp_rename 'Product', 'Products'; -- change table name
EXEC sp_rename 'Products.Name', 'NewColumnName', 'COLUMN'; -- change column name
EXEC sp_rename 'Products.IX_Product_Name', 'IX_Product_NewColumnName', 'INDEX'; -- change index name 
EXEC sp_rename 'PK_Product', 'PK_Products'; -- change primary key name
EXEC sp_rename 'FK_Color_Product_ProductId', 'FK_Color_Products_ProductId'; -- change foreign key name

上面是基本的操作, 但是我們需要自己把所有 relation 找出來哦. 參考: 我以前寫的 rename 筆記

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章