[SQL]基本表的定义及其完整性约束
在使用数据库时,绝大多数时间都是在使用基本表。
SQL Server数据类型
截图来源: https://www.w3school.com.cn/sql/sql_datatypes.asp
创建基本表
基本格式如下:
create table <表名>
(
<列名1> <数据类型> [<列级完整性约束条件>],
……
<列名n> <数据类型> [<列级完整性约束条件>]
[, <表级完整性约束条件>]
)
如果完整性约束涉及到多个属性列,则必须定义在表级上,否则可以定义在列级或表级。
如下创建一个Persons基本表:
use test -- 在该数据库中创建基本表
go
create table Persons
(
Id_P int primary key, -- Id_P为主键
LastName nvarchar(20),
FirstName nvarchar(20),
Address nvarchar(50),
City nvarchar(10)
)
go
完整性约束
完整性约束的用途是限制输入到基本表中的值的范围,SQL的完整性约束可分为列级完整性约束和表级完整性约束:
- 列级完整性约束:针对关系属性值的限定条件,只能应用在一列上
- 表级完整性约束:涉及关系中的多个属性的限制条件,可以应用在一个基本表中的多个列上。
如果完整性约束涉及到多个属性列,则必须定义在表级上,否则可以定义在列级或表级。当创建完整性约束之后,它作为基本表定义的一部分,存入数据字典中。
primary key约束
主键(primary key)约束是实体完整性约束,primary key用于定义主键,它保证主键的唯一性与非空性。一个基本表的主键由一列或者几列构成,可以定义在列级或者表级上,但是不能在两个级别上进行定义。
定义主键约束的方法如下:
primary key之间写在列名及其数据类型之后。例如:
create table test
(
col_name int primary key,
……
)
按照语法在相应的列名及其数据类型后单独列出:
constraint <约束名> primary key
约束名就是主键的名字。例如:
create table test
(
col_name int constraint PK_name primary key,
……
)
在create table语句中定义完所有列之后定义表级主键约束:
primary key (列名1, 列名2, ……)
或
constraint PK_name primary key (列名1, 列名2, ……)
例如:
create table test
(
col_name1 int,
col_name2 nvarchar(10),
……
constraint PK_name primary key (col_name1, col_name2)
)
foreign key约束
外键(foreign key)约束也称为参照表约束,用于定义参照完整性,即用来维护两个基本表之间的一致性关系。外键的建立主要是通过将一个基本表的主键(或者unique唯一性约束)所在的列包含在另一个表中,这些列就是另一个表的外键。
例如,因为销售订单和销售人员之间存在一种逻辑关系,所以 Sales.SalesOrderHeader
表含有一个指向 Sales.SalesPerson
表的外键链接。 SalesOrderHeader
表中的 SalesPersonID
列与 SalesPerson
表中的主键列相对应。 SalesOrderHeader
表中的 SalesPersonID
列是指向 SalesPerson
表的外键。 通过创建此外键关系,如果 SalesPerson
表的主键中不存在 SalesPersonID
的值,则 SalesPersonID
的值将无法插入到 SalesOrderHeader
表。
外键的作用不只是对输入自身表格的数据进行限制,同时也限制了对主键所在基本表的数据进行修改。主键所在的数据被另一张表的外键所引用时,用户将无法对主键中的数据进行修改或者删除,除非事先删除或修改引用的数据。
foreign key约束定义外键的方法如下:
如果外键只有一列,可以在它的列名和类型后面直接用references说明它参照了某个基本表的某些列(必须为主键):
references <表名> (<列名>)
在属性列表后面增加一个或几个外键说明,其语法格式为:
foreign key (<列名>) references <表名> (<列名>)
其中,第一个列名是外键,第二个列名是被参照基本表中的列名。
在相应的列名及其类型后单独列出并指定约束名,语法格式为:
constraint <约束名> foreign key (<列名>) references <表名> (<列名>)
unique约束
unique约束是唯一性约束,主要用来确保不受primary key约束的列上的数据的唯一性,两者的区别主要表现如下:
- unique约束主要用在非主键的一列或者多列上要求数据唯一的情况。
- unique约束允许该列上存在NULL值,而主键不允许。
- 一个表可设置多个unique约束,但是只能有一个主键约束。
unique约束可以在列级和表级上设置,但是要在多个列上设置unique约束必须设置表级约束。
定义unique约束的方法:
unique约束直接写在列名和数据类型之后
按照语法在相应的列名及其类型后单独列出:
constraint <约束名> unique
表级unique约束:
constraint <约束名> unique (<列名1> [, <列名2>, <列名2>,……])
check约束
check约束时检查约束,它通过检查输入表列的数据的值来维护值域的完整性,它依次检查每一个要进入数据库的数据,只有符合条件的数据才允许通过。check约束通过对一个逻辑表达式的结果进行判断来对数据进行检查。
default约束
default约束用于向列中插入默认值,如果没有规定其他的值,则添加默认值到所有新记录中。
not null或null约束
not null约束不允许列值为空,null约束允许列值为空。
create table 图书
(
图书号 varchar(15),
图书名称 varchar(30),
主编 varchar(30) not null,
出版社 varchar(15) default '清华大学出版社'
单价 float,
constraint CH_dj check (单价>=0 and 单价<=1000)
)
[SQL]基本表的定义及其完整性约束的更多相关文章
- SQL Server 表的管理_关于完整性约束的详解(案例代码)
SQL Server 表的管理之_关于完整性约束的详解 一.概述: ●约束是SQL Server提供的自动保持数据库完整性的一种方法, 它通过限制字段中数据.记录中数据和表之间的数据来保证数据的完整性 ...
- SQL 创建表
SQL 创建表是通过SQL CREATE TABLE 语句来实现,该语句是DDL SQL语句.CREATE TABLE语句用于创建用于存储数据的表.在创建表时,可以为列定义主键.惟一键和外键等完整性约 ...
- SQL Server 表变量和临时表的区别
SQL Server 表变量和临时表的区别 一.表变量 表变量在SQL Server 2000中首次被引入.表变量的具体定义包括列定义,列名,数据类型和约束.而在表变量中可以使用的约束包括主键约束,唯 ...
- SQL Server表分区【转】
转自:http://www.cnblogs.com/knowledgesea/p/3696912.html SQL Server表分区 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在 ...
- SQL语言学习-数据定义语言
Sql语言至今已经有6个版本.SQL查询语言包括了所有对数据的操作命令,这些操作可分为四类:数据定义语言(DDL).数据操纵语言(DML).数据控制语言(DCL)和嵌入式SQL语言. 数据定义语言(D ...
- SQL Server表分区详解
原文:SQL Server表分区详解 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个文件里. 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆 ...
- [转]SQL Server 表变量和临时表的区别
一.表变量 表变量在SQL Server 2000中首次被引入.表变量的具体定义包括列定义,列名,数据类型和约束.而在表变量中可以使用的约束包括主键约束,唯一约束,NULL约束和CHECK约束(外键约 ...
- 数据库概论_3标准化的SQL语言_ 数据定义
Student: Course: SC: 1.数据库的定义.删除 1.1数据库的定义(创建) CREATE DATABASE student; 1.2数据库的删除 DROP DATABASE stud ...
- oracle SQL多表查询
SQL多表查询 1.集合理论 1.1 什么是集合 具有某种特定性质的事物的总体. 集合的特性:无序性.互异性.确定性. 一个集合可以小到从一个表中取出一行中的一列. 1 ro ...
随机推荐
- as3.0 Flex 图像处理
as3.0 Flex 图像处理 已知的一些图像处理,主要是得到颜色过滤矩阵,不完整,大家一起来补充. //颜色转换数组,所有的0都是可调值public var colorArray:Array = [ ...
- Gym 101334E dp
分析: 这一题给出的遍历的点的序列,不是树的中序遍历,前序遍历,只要遇到一个节点就打印一个节点.关键点就在,这个序列的首字母和尾字母一定要相同,因为最终都会回到根节点,那么每一个子树也一样. 状态: ...
- 资源:CentOS下载地址资源
新版本系统镜像下载(当前最新是CentOS 7.4版本) CentOS官网 官网地址 http://isoredirect.centos.org/centos/7.4.1708/isos/x86_64 ...
- Https:创建部署SSL证书进行双向认证
一.前言 建立客户端与服务器的Https的连接需要证书进行双向验证后,才可访问. 二.证书类型 不同数字证书部署在服务器上后,用户浏览器访问网站时,展示如下: 1.无证书时 显示不安全标识. 2. ...
- 23 shell 进程替换
0.shell进程替换的用法 1.使用进程替换的必要性 2.进程替换的本质 进程替换和命令替换非常相似.命令替换是把一个命令的输出结果赋值给另一个变量,例如dir_files=`ls -l`或date ...
- (学习心路历程)Vue过渡/动画 VS. 过渡/动画
[此篇为本人的个人见解和哔哔赖赖,如果有观点不对的地方,还请大家指出来哇!!] 最近实习在做一个项目,里面应用的动画效果还蛮复杂的,因为本身对Vue框架比较熟悉,所以最终选择了Vue框架. 自己之前从 ...
- JUnit5参数化测试的几种方式
参数化测试一直是津津乐道的话题,我们都知道JMeter有四种参数化方式:用户自定义变量.用户参数.CSV文件.函数助手,那么JUnit5有哪些参数化测试的方式呢? 依赖 JUnit5需要添加junit ...
- 常见内部排序算法对比分析及C++ 实现代码
内部排序是指在排序期间数据元素全部存放在内存的排序.外部排序是指在排序期间全部元素的个数过多,不能同时存放在内存,必须根据排序过程的要求,不断在内存和外存之间移动的排序.本次主要介绍常见的内部排序算法 ...
- 锐捷路由器 RSR20-X-28
学习帮助视频 Ruijie#show run | in natip nat outsideip nat insideip nat pool NAT_POOL prefix-length 24ip na ...
- C语言:预处理命令总结
预处理指令是以#号开头的代码行,# 号必须是该行除了任何空白字符外的第一个字符.# 后是指令关键字,在关键字和 # 号之间允许存在任意个数的空白字符,整行语句构成了一条预处理指令,该指令将在编译器进行 ...