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

 

创建 Primary Key

alter table [TableName] add constraint [PK_PrimaryKey] primary key clustered (Id);

 

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

 

Drop Index

drop index [TableName].[IndexName];

不管是 clustered, nonclustered 都是这样 drop.

 

Drop Primary Key or Foreign Key

alter table [TableName] drop constraint [PK_PrimaryKey]; -- drop primary key
alter table [TableName] drop constraint [FK_ForeignKey]; -- drop foreign key

 

查看当前 SQL Server 版本

select @@version;

 

posted @   兴杰  阅读(290)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
历史上的今天:
2018-11-13 Asp.net core (学习笔记 路由和语言 route & language)
2015-11-13 SQL basic
点击右上角即可分享
微信分享提示