在实际开发中,可能很少人会手写sql脚本来操作数据库的种种。特别是微软的MS SQL Server数据库,它的SQL Server Management Studio对数据库的图形化操作极致简便,从而导致很多人都不会或不熟悉使用SQL脚本操作数据库。

接下面介绍的是我们日常开发中常规性的各种操作,先看看基本知识,随后使用coding来表述。

SQL Server 常见五种约束:

  Primary Key  --主键约束
  Foreign Key  --外键约束
  Unique     --唯一约束
  Default     --默认值约束
  Check     --条件约束(逻辑判断约束)

什么是主键?

在数据库中,常常不只是一个表,这些表之间也不是相互独立的。不同的表之间需要建立一种关系,才能将它们的数据相互沟通。而在这个沟通过程中,就需要表中有一个字段作为标志,不同的记录对应的字段取值不能相同,也不能是空白的。通过这个字段中不同的值可以区别各条记录。就像我们区别不同的人,每个人都有名字,但它却不能作为主键,因为人名很容易出现重复,而身份证号是每个人都不同的,所以可以根据它来区别不同的人。数据库的表中作为主键的字段就要像人的身份证号一样,必须是每个记录的值都不同,这样才能根据主键的值来确定不同的记录。

如果为表指定了 PRIMARY KEY 约束,则 SQL Server 2005 数据库引擎 将通过为主键列创建唯一索引来强制数据的唯一性。当在查询中使用主键时,此索引还可用来对数据进行快速访问。因此,所选的主键必须遵守创建唯一索引的规则。

创建主键时,数据库引擎 会自动创建唯一的索引来强制实施 PRIMARY KEY 约束的唯一性要求。如果表中不存在聚集索引或未显式指定非聚集索引,则将创建唯一的聚集索引以强制实施 PRIMARY KEY 约束。

唯一性约束
1) 唯一性约束所在的列允许空值,但是主键约束所在的列不允许空值。
(2) 可以把唯一性约束放在一个或者多个列上,这些列或列的组合必须有唯一的只。但是,唯一性约束所在的列并不是表的主键列。
(3) 唯一性约束强制在指定的列上创建一个唯一性索引。在默认情况下,创建唯一性的非聚簇索引,但是,也可以指定所创建的索引是聚簇索引。

主键: 
1) 用于标识某行而且与之相关. 
2) 是不可能(或很难)更新. 
3) 不应该允许空(NULL).

唯一域/字段: 
1) 用于作为访问某行的可选手段.
2) 只要唯一就可以更新. 
3) 可以为空(NULLs).

注意唯一和主键的区别,它们都是创建一个唯一的索引,一个表格仅含有一个主键约束列,但是,它有可能在其他列中含有许多的唯一约束。

1、Primary Key约束

在表中常有一列或多列的组合,其值能唯一标识表中的每一行。

这样的一列或多列成为表的主键(PrimaryKey)。一个表只能有一个主键,而且主键约束中的列不能为空值。只有主键列才能被作为其他表的外键所创建。

2、Foreign Key约束

外键约束是用来加强两个表(主表和从表)的一列或多列数据之间的连接的。创建外键约束的顺序是先定义主表的主键,然后定义从表的外键。也就是说只有主表的主键才能被从表用来作为外键使用,被约束的从表中的列可以不是主键,主表限制了从表更新和插入的操作。

3、Unique约束

唯一约束确保表中的一列数据没有相同的值。与主键约束类似,唯一约束也强制唯一性,但唯一约束用于非主键的一列或者多列的组合,且一个表可以定义多个唯一约束。

4、Default约束

若在表中定义了默认值约束,用户在插入新的数据行时,如果该行没有指定数据,那么系统将默认值赋给该列,如果我们不设置默认值,系统默认为NULL。

5、Check约束

Check约束通过逻辑表达式来判断数据的有效性,用来限制输入一列或多列的值的范围。在列中更新数据时,所要输入的内容必须满足Check约束的条件,否则将无法正确输入。

---创建数据库,语句: create database 表名

Create database School

----删除数据库,语句:drop database 表名

drop database School

--创建数据表,语句:create table 表名( 字段A 类型 可空, 字段B 类型 可空)

Create Table Grade(
Id int not null identity(1,1), --identity 设置字段自增长,步进值为1
Name nvarchar not null
)

--创建主键约束,语句: alter table 表名 add constraint [主键名称] primary key (主键字段)

alter table Grade Add constraint [PK_Grade] primary key (Id)

--创建唯一约束,语句: alter table 表名 add constraint [约束名称] unique (字段 排序)

alter table Grade add constraint [IX_Grade_Name] unique (Id asc)

--创建数据表,语句:create table 表名( 字段A 类型 可空, 字段B 类型 可空)

create Table Student(
Id int not null identity,
Cid int not null,
Name nvarchar(100) not null,
Gender nchar(8) not null
)

--创建主键约束,语句: alter table 表名 add constraint [主键名称] primary key (主键字段)

alter table Student Add constraint PK_Student primary key (Id)

--创建外键约束,语句: alter table 表名 add constraint [外键名称] foreign key (字段) references 外链表名(字段)

alter table Student Add constraint FK_Student_Cid foreign key (Id) references Grade(Id)

--创建唯一约束,语句:alter table 表名 add constraint [约束名称] unique (字段 排序)

alter table Student Add constraint IX_Student_Name unique (Id desc)

--创建Default约束,语句:alter table 表名 add constraint [约束名称] default (默认值) for (字段)

alter table Student add constraint DF_Student_Gender default (N'男') FOR [Gender]

--创建Check约束,语句:alter table 表名 add constraint [约束名称] check (逻辑表达式)

alter table Student add constraint CK_Student_Gender CHECK (([Gender]=N'男' OR [Gender]=N'女'))

--删除约束,语句: alter table 表名 drop constraint [约束名称]

alter table Student drop constraint IX_Student_Name

--修改字段,语句:alter table 表名 alter column [字段名] 类型 可空

alter table Grade alter column [Name] nvarchar(100) not null

--添加字段,语句:alter table 表名 add [字段名] 类型 可空

alter table Grade add [Year] char(8) not null

--删除字段,语句:alter table drop column [字段名]

alter table Grade drop column [Year]

--填充数据

insert into Grade select N'一年级','2017'  --方法一
insert into Grade(Name,[Year]) values (N'二年级','2017')  --方法二
insert into Grade select N'三年级','2017'insert into Student select 2,N'张三','男'
insert into Student select 2,N'李四','男'
insert into Student select 3,N'王五','男'
insert into Student select 3,N'赵六','男'
insert into Student select 3,N'马七','女'

--假设由于业务变更,我们需要给Student表新增非空IdNumber字段--

明天继续....

转载于:https://www.cnblogs.com/event/p/6433544.html

使用SQL脚本创建数据库,操作主键、外键与各种约束(MS SQL Server)相关推荐

  1. sql语句创建表的同时添加外键约束

    sql语句创建表的同时添加外键约束 题目 建立一个商店的数据库store,记录顾客及其购物情况,由下面三个表组成: 商品(商品号,商品名,单价,商品类别,供应商): 顾客(顾客号,姓名,住址): 订单 ...

  2. mysql外键约束脚本_使用SQL脚本创建数据库,操作主键、外键与各种约束(MS SQL Server)...

    在实际开发中,可能很少人会手写sql脚本来操作数据库的种种.特别是微软的MS SQL Server数据库,它的SQL Server Management Studio对数据库的图形化操作极致简便,从而 ...

  3. 使用sql脚本创建数据库表

    准备脚本语句: CREATE TABLE `test` (`title` varchar(100) DEFAULT NULL,`author` varchar(10) DEFAULT NULL,`di ...

  4. php sqlserver开发实例,Linux_用sql脚本创建sqlserver数据库范例语句,下面是创建一个sqlserver数据库 - phpStudy...

    用sql脚本创建sqlserver数据库范例语句 下面是创建一个sqlserver数据库的代码模板,加上一个创建表的模板.开发的时候可以拷贝过去直接改动一下就可以用了. 希望能帮上忙! 复制代码 代码 ...

  5. 使用SQL语句创建数据库和数据库表

    使用SQL语句创建数据库和数据库表 内容如下: 创建数据库 创建数据库表 1.创建数据库的语句 创建数据库,需要创建数据库的数据文件和日志文件 其中一些语句含义如下: 语句 代表含义 name 逻辑文 ...

  6. 在MySQL中如何用SQL命令创建数据库及数据表

    HRELLO 大家好! 上期给大家讲解了,MySQL数据库常用的管理命令.现在,给大家讲解,如何用SQL命令在MySQL中创建一个数据库及数据表. 在学习前,我们首先要了解,SQL命令是什么? SQL ...

  7. 使用了无效的sql语句_使用SQL语句创建数据库

    使用SQL语句创建数据库(SQL Server 2008) 创建一个名为'DA_sales'的数据库. 主文件组'DA_sales_data'(初始大小:5MB;最大值:200MB;自动增长率:10% ...

  8. Oracle数据库初学者:sql语句创建数据库表空间,建表语句

    1. 表空间的创建 表空间的创建,格式: create tablespace 表空间名 datefile '路径名/表空间名.dbf' size 60M(初始空间大小为:60M) autoextend ...

  9. SQL语句创建数据库

    SQL语句创建数据库 SQL语句如下: create database 数据库名称on(name=数据文件逻辑名称,filename='路径+数据文件名',size=数据文件初始大小,maxsize= ...

最新文章

  1. 图灵机与控制论之分歧,一切为了人类心智的荣耀!
  2. RMB符号的几种显示方式。
  3. P2P中DHT网络原理
  4. C语言宏定义中使用 do{}while(0) 的情形
  5. order by 空值排在最后_当梅根·马克尔最后一次皇室活动选择选择翡翠绿时证明她非常时髦...
  6. opengl加载显示3D模型ZGL类型文件
  7. gateway网关配置入门
  8. SpringCloudBus(了解)
  9. mysql 搜索不等于_Mysql索引分类
  10. 辽宁师范大学计算机学院邹丽,邹丽(运载工程与力学学部)老师 - 大连理工大学 - 院校大全...
  11. RedMonk最新编程语言排行榜出炉:JS霸榜,C++下降至第7
  12. yii2搭建完美后台并实现rbac权限控制实例教程
  13. mysql语句错误怎么查找_SQL语法错误但是怎么也找不出来,求指导
  14. 在VS2008中使用jQuery智能感应
  15. 考研笔记——王道C语言
  16. 基于java的智能计算器_基于Java的语音计算器实现
  17. java发送邮件带图片和附件
  18. 脚本小子_Lua安装教程
  19. Unity 之 UGUI Dropdown下拉选单组件详解
  20. 本体学习方法及开发过程小结

热门文章

  1. 基于Android Studio搭建cordova开发环境
  2. maven给默认中央仓库设置镜像为阿里云maven仓库并添加全局远程仓库
  3. Scala 键盘录入对象StdIn/特质/伴生对象
  4. eureka服务续约机制
  5. Python3逻辑运算符
  6. Java计算多线程运行时间的简单方式
  7. spring整合webservice
  8. Spring 已经实现的线程池
  9. 【报表技术】IReport 图形化报表开发工具安装教程
  10. centos7中每天定时备份mysql数据库