MSSQL系列 (二):表相关操作、列操作、(唯一、主键、默认、检查、外键、非空)约束、临时表
1.创建表
--创建学生班级表
create table StuClass
(
ClassId int primary key, --班级ID 主键约束
ClassName nvarchar(30) not null unique, --班级名称 非空约束 唯一约束
CreateDate datetime default getdate(), --创建时间 默认值约束
IsDelete nvarchar(1) default 'N' --是否删除 默认'N' 'Y'代表删除'N'代表不删除 默认值约束
)
go --创建学生表
create table Student
(
StuId int primary key identity(1,1), --学生ID 主键约束 自增长
StuName nvarchar(30) not null, --学生姓名 非空约束
StuSex nvarchar(2) check(stuSex='男' or stuSex='女'), --学生性别 只是女或者男 检查约束
CreateDate datetime default getdate(), --创建时间 默认当前时间 默认值约束
StuAge int, --学生年龄 无约束
ClassId int foreign key (ClassId) references StuClass (ClassId), --班级ID 外键
IsDelete nvarchar(1) default 'N' --是否删除 默认'N' 'Y'代表删除'N'代表不删除
)
go --创建学生科目表
create table StuSubject(
SubjectId int primary key, --科目ID
SubjectName nvarchar(30) , --科目名称
)
go --创建学生成绩表
create table StuScore(
StuId int foreign key (StuId) references Sutdent(StuId) on delete cascade, --学生ID 外键约束 同时支持级联删除
SubjectId int foreign key (SubjectId) references StuSubject(SubjectId) on delete cascade , --学生科目 外键约束
StuScore float, --学生成绩
primary key(StuId,SubjectId) --联合主键
)
go
2.约束相关操作(添加、删除)
--添加约束的另一种方式 注意:两种方式只能用一种
--添加主键约束
alter table StuScore add constraint PK_StuScore_StuId_SubjectId primary key (StuId)
go --添加非空约束
alter table StuScore alter column StuScore float not null
go --添加检查约束
alter table StuInfo add constraint CK_StuInfo_StuSex check(StuSex='男' or StuSex='女')
go --添加唯一约束
alter table StuClass add constraint UQ_StuClass_ClassName unique(ClassName)
go --添加默认值约束
alter table StuClass add constraint DF_StuClass_CreateDate default(getdate()) for CreateDate
go --添加外键约束
alter table StuInfo add constraint FK_StuClass_StuInfo foreign key (ClassId) references StuClass(ClassId) on delete cascade
go --删除单个约束
alter table StuScore drop FK_StuClass_StuInfo
go --删除多个约束
alter table StuScore drop constraint
FK_StuClass_StuInfo,
PK_StuScore_StuId_SubjectId
go
3.列相关操作
--添加列
alter table StuScore add CreateDate datetime default getdate();
go --删除列
--删除列名的时候 如果存在约束 要删除约束
alter table StuScore drop DF__StuScore__Create__403A8C7D
alter table StuScore drop column CreateDate
go --修改列字段类型
alter table StuScore alter column StuScore float
go --修改表名
--注意:更改对象名的任何部分都可能破坏脚本和存储过程,谨慎操作
exec sp_rename 'Student','StuInfo'
go --修改表中的列名
--注意:更改对象名的任何部分都可能破坏脚本和存储过程,谨慎操作
exec sp_rename 'StuInfo.CreateDate','CreateTime','column'
go
4.删除表
--删除表 注意当有主从表时候 先删从表 如果设置了联级删除 那么都会删除
if exists(select count(*) from sys.objects where name='StuScore')
drop table StuScore
go
5.临时表相关操作
--删除临时表
if object_id('tempdb..#StuInfo') is not null
drop table #StuInfo
go --创建临时表
create table #StuInfo
(
StuId int primary key identity(1,1), --学生ID 主键约束 自增长
StuName nvarchar(30) not null, --学生姓名 非空约束
StuSex nvarchar(2) check(stuSex='男' or stuSex='女'), --学生性别 只是女或者男 检查约束
CreateDate datetime default getdate(), --创建时间 默认当前时间 默认值约束
StuAge int, --学生年龄 无约束
IsDelete nvarchar(1) default 'N' --是否删除 默认'N' 'Y'代表删除'N'代表不删除 默认值约束
)
MSSQL系列 (二):表相关操作、列操作、(唯一、主键、默认、检查、外键、非空)约束、临时表的更多相关文章
- MS SQL巡检系列——检查外键字段是否缺少索引
前言感想:一时兴起,突然想写一个关于MS SQL的巡检系列方面的文章,因为我觉得这方面的知识分享是有价值,也是非常有意义的.一方面,很多经验不足的人,对于巡检有点茫然,不知道要从哪些方面巡检,另外一方 ...
- MySQL 非空约束位置不同对自增列造成的影响
MySQL版本 select version(); +------------+ | version() | +------------+ | 5.7.21-log | +------------+ ...
- glance系列二:glance部署及操作
一 简单架构图示参考 更新中... 二 部署glance yum install memcached python-memcachedsystemctl enable memcached.servic ...
- MongoDB 系列(二) C# 内嵌元素操作 聚合使用
"_id" : "639d8a50-7864-458f-9a7d-b72647a3d226","ParentGuid" : "00 ...
- dplyr 数据操作 列操作(select / mutate)
在R中,我们通常需要对数据列进行各种各样的操作,比如选取某一列.重命名某一列等. dplyr中的select函数子在数据列的操作上也同样表现了它的简洁性,而且各种操作眼花缭乱. select(.dat ...
- MySQL数据库(三)—— 表相关操作(二)之约束条件、关联关系、复制表
表相关操作(二)之约束条件.关联关系.复制表 一.约束条件 1.何为约束 除了数据类型以外额外添加的约束 2.约束条件的作用 为了保证数据的合法性,完整性 3.主要的约束条件 NOT NULL # ...
- MySQL数据库(三)--表相关操作(二)之约束条件、关联关系、复制表
一.约束条件 1.何为约束 除了数据类型以外额外添加的约束 2.约束条件的作用 为了保证数据的合法性,完整性 3.主要的约束条件 NOT NULL # 标识该字段不能为空,默认NULL,可设置NOT ...
- MySql学习笔记【三、表相关操作】
创建表 CREATE TABLE [IF NOT EXISTS] table_name( column_name data_type, ... ) 如: CREATE TABLE test_table ...
- 第八章| 1. MySQL数据库|库操作|表操作
1.初识数据库 我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端程序),于是有人将此类程序写成一个 专门的处理软件,这就是mysql等数据库管理软件的 ...
随机推荐
- JS新界面关闭原界面刷新的多种形式
------------恢复内容开始------------ 1.新界面为当前界面弹出的形式: 第一步:首先原界面的原生JS事件需要放到 (function () { ...... })(); 中 ...
- Hystrix总结
Hystrix 能使你的系统在出现依赖服务失效的时候,通过隔离系统所依赖的服务,防止服务级联失败,同时提供失败回退机制,更优雅地应对失效,并使你的系统能更快地从异常中恢复. Hystrix能做什么? ...
- git 远程分支和tag标签的操作
git远程分支操作:1.创建远程分支git push --set-upstream origin develop:develop2在服务器创建远程分支devlop2,让本地的develop分支和dev ...
- java后台框架面试必须会的东西
- 入门大数据---SparkSQL_Dataset和DataFrame简介
一.Spark SQL简介 Spark SQL 是 Spark 中的一个子模块,主要用于操作结构化数据.它具有以下特点: 能够将 SQL 查询与 Spark 程序无缝混合,允许您使用 SQL 或 Da ...
- 使用docker创建redis容器
1.拉取redis镜像
- SQL运行内幕:从执行原理看调优的本质
相信大家看过无数的MySQL调优经验贴了,会告诉你各种调优手段,如: 避免 select *: join字段走索引: 慎用in和not in,用exists取代in: 避免在where子句中对字段进行 ...
- CString 十六进制转二进制
int nValude = 0; CString strtemp("asdb");; sscanf(strtemp.GetBuffer(0),"%x",& ...
- C#状态机Stateless
最近在折腾一些控制相关的软件设计,想起来状态机这个东西,对解决一些控制系统状态切换还是挺有用的. 状态机(有限状态自动机)网上有很多介绍.简单理解就是定义一系列状态,通过一系列的事件,可以使得状态可以 ...
- python-多任务-进程
什么是进程? 程序是静态的,当程序运行起来就叫做进程. 进程是操作系统分配资源的基本单元. 进程.线程的区别与优缺点 1. 定义的不同: 进程是系统进行资源分配的最小单位. 线程是进程的一个实体,是C ...