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 笔记

 

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