前言

日常都是用 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的更多相关文章

  1. SQL Server中Table字典数据的查询SQL示例代码

    SQL Server中Table字典数据的查询SQL示例代码 前言 在数据库系统原理与设计(第3版)教科书中这样写道: 数据库包含4类数据: 1.用户数据 2.元数据 3.索引 4.应用元数据 其中, ...

  2. SQL Server基本操作积累

    一.基本操作 1.将数据绑定到DataGridVirw控件上显示的数据列标题将会是数据库中的字段名称,可以在使用select语句时使用AS关键字将转化为列名的别名 select name AS 姓名 ...

  3. SQL Server 关于 Table 字典数据的查询SQL

    分享一个关于查询SQL Server Table 结构的SQL 语句. T-SQL 如下: SELECT (case when a.colorder=1 then d.name else '' end ...

  4. sql server 基本操作

    1输入如下命令,即可通过SQL Server命令行启动.停止或暂停的服务. SQL Server命令行如下: 启动SQL ServerNET START MSSQLSERVER 暂停SQL Serve ...

  5. [转]SQL Server 2008- Get table constraints

    本文转自:https://stackoverflow.com/questions/14229277/sql-server-2008-get-table-constraints You should u ...

  6. 14-3 SQL Server基本操作

    SQL Server安装默认新建四个系统数据库 1.master数据库 Master数据库时SQL Server中最重要的数据库.它记录SQL Server实例的所有系统级信息,包括实例范围的元数据. ...

  7. SQL SERVER 基本操作语句

    Sql 是一种结构化的查询语言:Sql是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理‘关系型数据库’系统:Sql对大小写不敏感:Sql不是数据库,是行业标准,是结构化的查询语言 In ...

  8. SQL Server: create table sql script

    ---摇奖observeh数据库设计 Function getSpace lottery /* -- Author:geovindu 涂聚文 -- Date: 20180427 为了自写生成代码.根据 ...

  9. SQL server基本操作(一)

      --1.create database CREATE DATABASE MyDB GO --2.use database USE MyDB GO --3.create table CREATE T ...

  10. 获得sql server的table的表结构 -- 转到word中

    SQL语句: select syscolumns.name,systypes.name,syscolumns.length from syscolumns  join sysobjects on sy ...

随机推荐

  1. 数学工具 | 如何将图片公式快速输入到Word中?

    背景: 在日常科研.学习与工作中,我们可能需要使用到某些书籍.期刊或者规范上的公式,但是如果自己纯手打则会相当麻烦(数学系LaTeX高手请忽略),因此如果有工具能够解决这个问题,那真的是解决了一大痛点 ...

  2. Memcache 与 Memcached 的区别

    Memcached 从0.2.0开始,要求PHP版本>=5.2.0,Memcache 要求PHP版本>=4.3. Memcached 最后发布时间为2018-12-24,Memcache ...

  3. PAT-1002 写出这个数 (20分) JavaScript(node)

    读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 10100​​ . 输出格式: 在一行 ...

  4. Odoo 美化登录界面

    实践环境 Odoo 14.0-20221212 (Community Edition) Odoo Web Login Screen 14.0 https://apps.odoo.com/apps/mo ...

  5. 搭建lnmp环境-nginx关联php-fpm (第三步)

    永久关闭防火墙sudo systemctl stop firewalldsudo systemctl disable firewall 有两个防火墙!如果上面那个关闭还不行,就继续关这个后重启.   ...

  6. k8s(3) 集群运行

    Master下面执行 mkdir -p $HOME/.kube 执行的脚本,需要读取的配置文件 cp -i /etc/kubernetes/admin.conf $HOME/.kube/config ...

  7. Jmeter函数助手3-RandomString

    RandomString函数用于生成指定内容范围的指定长度随机字符. Random string length:限制生成的长度,比如输入6则会生成6位字符 Chars to use for rando ...

  8. 4、SpringMVC之获取请求参数

    4.1 环境搭建 创建名为spring_mvc_demo2的新module,过程参考3.1节 4.1.1.创建请求控制器 package org.rain.controller; import org ...

  9. 【Vue】Re01 理论概念和入门上手

    一.Vue概述 什么是渐进式?1.把Vue作应用的一部分嵌套项目中2.如果完全抛弃其他组件和框架,Vue又具有丰富的生态和库莱支持3.Core + Router + VueX 满足项目绝大多数的需求- ...

  10. NVIDIA 2024 GTC大会提出的数字孪生技术 —— 工厂3D仿真与AI大模型结合

    地址: https://www.youtube.com/watch?v=JQdyzQdMRS0 Fusing Real-Time AI With Digital Twins 使用NVIDIA的3D仿真 ...