前言
日常都是用 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
或者
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 筆記