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
或者
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;
SQL Server – 基本操作 Table 和 Column的更多相关文章
- SQL Server中Table字典数据的查询SQL示例代码
SQL Server中Table字典数据的查询SQL示例代码 前言 在数据库系统原理与设计(第3版)教科书中这样写道: 数据库包含4类数据: 1.用户数据 2.元数据 3.索引 4.应用元数据 其中, ...
- SQL Server基本操作积累
一.基本操作 1.将数据绑定到DataGridVirw控件上显示的数据列标题将会是数据库中的字段名称,可以在使用select语句时使用AS关键字将转化为列名的别名 select name AS 姓名 ...
- SQL Server 关于 Table 字典数据的查询SQL
分享一个关于查询SQL Server Table 结构的SQL 语句. T-SQL 如下: SELECT (case when a.colorder=1 then d.name else '' end ...
- sql server 基本操作
1输入如下命令,即可通过SQL Server命令行启动.停止或暂停的服务. SQL Server命令行如下: 启动SQL ServerNET START MSSQLSERVER 暂停SQL Serve ...
- [转]SQL Server 2008- Get table constraints
本文转自:https://stackoverflow.com/questions/14229277/sql-server-2008-get-table-constraints You should u ...
- 14-3 SQL Server基本操作
SQL Server安装默认新建四个系统数据库 1.master数据库 Master数据库时SQL Server中最重要的数据库.它记录SQL Server实例的所有系统级信息,包括实例范围的元数据. ...
- SQL SERVER 基本操作语句
Sql 是一种结构化的查询语言:Sql是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理‘关系型数据库’系统:Sql对大小写不敏感:Sql不是数据库,是行业标准,是结构化的查询语言 In ...
- SQL Server: create table sql script
---摇奖observeh数据库设计 Function getSpace lottery /* -- Author:geovindu 涂聚文 -- Date: 20180427 为了自写生成代码.根据 ...
- SQL server基本操作(一)
--1.create database CREATE DATABASE MyDB GO --2.use database USE MyDB GO --3.create table CREATE T ...
- 获得sql server的table的表结构 -- 转到word中
SQL语句: select syscolumns.name,systypes.name,syscolumns.length from syscolumns join sysobjects on sy ...
随机推荐
- xampp+vscode 安装PHP断点调试xdebug
官网下载地址:https://xdebug.org/download.php 这里需要特别注意,有TS(thread safe)和NTS 区别,我建议不要下载最新的,我一开始使用最新的发现插件没有匹配 ...
- GitHub Star 数量前 12 的开源无代码工具
相关文章:GitHub Star 数量前 15 的开源低代码项目 在本篇文章中,我们将探索 12 款在 GitHub 上星级排名前列的开源无代码工具. 每款工具都旨在简化和加速开发过程,但各自侧重于不 ...
- Vue 基于VSCode结合Vetur+ESlint+Prettier统一Vue代码风格
基于VSCode结合Vetur+ESlint+Prettier统一Vue代码风格 插件安装 安装Vetur,ESlint, Prettier - Code formatter插件 安装方法(安装ESl ...
- 计算复杂性学习笔记(TCS笔记)
感觉最近太摆了,每天很空虚,不愿意搞应试那一套,还是得学点东西.还是准备一边学tcs一边搞搞oi好打icpc,搞这个纯属兴趣,也是填个坑.最近进了一个初中生建的数学交流群,感觉群里初中生也很厉害,开始 ...
- Django+Bootstrip 卡片模板设计 经典精品
下面是一个完整的卡片模板代码,包含所有元素,并使用Django的模板语言来处理状态字段的条件渲染.同时还包括示例视图和URL配置. 完整的卡片模板 <div class="card&q ...
- Java工具库——Hutool的常用方法
Hutool-All(或简称Hutool)是一个功能强大的Java编程工具库,旨在简化Java应用程序的开发. 它提供了大量的工具类和方法,涵盖了各种常见任务,包括字符串处理.日期时间操作.文件操作. ...
- FFmpeg开发笔记(四十四)毕业设计可做的几个拉满颜值的音视频APP
一年一度的毕业季就要到了,毕业设计算是大学生毕业前的最后一个大作业,尤其是计算机相关专业的毕业设计,通常要通过编程开发一个软件,比如开发一个图书馆管理系统,开发一个电商APP等等. 一个好的毕业设计 ...
- 感慨!美国人的大学课程搞的确实蛮好的,不是那种刻板读书的感觉 —— 课程:SERVICE-ORIENTED COMPUTING AND SYSTEM INTEGRATION: SOFTWARE, IOT, BIG DATA, AND AI AS SERVICES
无意间看到了一个美国人的课程,使用的教材:<SERVICE-ORIENTED COMPUTING AND SYSTEM INTEGRATION: SOFTWARE, IOT, BIG DATA, ...
- python之理解super及MRO列表 ( 示例版 )
例子 1: class A0: def pri(self): super().pri() print("A0") class A1(A0): def pri(self): su ...
- MindSpore中使用model.train,在每一步训练结束后自动进行调用自定义函数 —— from mindspore.train.callback import Callback
在MindSpore中使用model.train训练网络时我们难以处理间断性的任务,为此我们可以考虑使用MindSpore中的Callback机制.Callback 函数可以在 model.train ...