Sql 六种约束
--1.主键约束问题
create table 学生表(
学号 int primary key,
姓名 varchar(10)
);
insert into 学生表 values(null,'a');
问题(无法执行)
原因(主键不能为空)
insert into 学生表 values(1,'a');
insert into 学生表 values(1,'b');
问题(无法执行)
原因(主键不能重复)
insert into 学生表 values(1,'a');
insert into 学生表 values(2,'b');
能执行
select * from 学生表;
--2.非空约束问题
create table 学生表(
学号 int primary key,
姓名 varchar(10) not null
);
insert into 学生表 values(1,null);
insert into 学生表(学号) values(1);
问题(不能将null插入姓名)
因为(列“姓名”有not null约束)
select * from 学生表;
--3.检查约束问题
drop table 学生表;
create table 学生表(
学号 int primary key,
姓名 varchar(10),
年龄 int check(年龄<18)
);
insert into 学生表 values(1,'a',20);
问题(与"check"约束冲突)
原因(年龄字段的值必须<18)
insert into 学生表 values(1,'b',null);
能执行,原因是有检查约束的列可以接受null值,null不能与任何值比较
insert into 学生表(学号,姓名) values(3,null);
能执行,原因是没有指定约束,则默认可以为空
select * from 学生表;
--4.唯一约束问题
drop table 学生表;
create table 学生表(
学号 int primary key,
姓名 varchar(10),
身份证 char(18) unique
);
insert into 学生表 values(1,'a',null);
insert into 学生表 values(2,'b',null);
问题(违反了“unique”约束)
原因(在SQL Sever中,唯一列不能有两个null值)
注:在其他数据库中,唯一是可以有多个null值
select * from 学生表;
--5.默认约束问题
drop table 学生表;
create table 学生表(
学号 int primary key,
姓名 varchar(10),
性别 char(2) default '女'
);
insert into 学生表(学号,姓名) values(1,'a');
select * from 学生表;
--6.外键约束问题
create database 班级表(
班级编号 int primary key,
班级名称 varchar(10)
);
drop table 学生表;
create table 学生表(
学号 int primary key,
姓名 varchar(10),
班级编号 int,foreign key (班级编号) references 班级表(班级编号)
);
insert into 学生表 value(1,'a',1);
insert into 班级表 values(1,'一班');
insert into 班级表 values(2,'二班');
insert into 学生表 values(3,'a',null);
问题(没有问题)
原因(当外键为null时,是无法与班级编号进行比较的;
从业务上讲,此学生目前不在任何班)
insert into 学生表 values(4,'b',3);
问题(与约束“fk”有冲突)
原因(3号班级在班级表中不存在无法引用)
delete from 班级表 where 班级编号=1;
问题(与约束“fk”冲突)
原因(1号班级被引用,不能被删除)
select * from 学生表;
select * from 班级表;
--外键小结
.不能在子表插入一个父表不存在的编号,但可以为空
.不能删除父表中被引用的编号
.(不能将子表中的外键更新为一个父表不存在的编号)
.外键的本质就是:不能引用一个不存在的对象,
不能删除一个被引用的对象
====本文来自新浪张婷博客
Sql 六种约束的更多相关文章
- SQL PRIMARY KEY 约束\SQL FOREIGN KEY 约束\SQL CHECK 约束
SQL PRIMARY KEY 约束 PRIMARY KEY 约束唯一标识数据库表中的每条记录. 主键必须包含唯一的值. 主键列不能包含 NULL 值. 每个表都应该有一个主键,并且每个表只能有一个主 ...
- SQL CREATE TABLE 语句\SQL 约束 (Constraints)\SQL NOT NULL 约束\SQL UNIQUE 约束
CREATE TABLE 语句 CREATE TABLE 语句用于创建数据库中的表. SQL CREATE TABLE 语法 CREATE TABLE 表名称 ( 列名称1 数据类型, 列名称2 数据 ...
- 扩展Exception,增加判断Exception是否为SQL引用约束异常方法!
在设计数据表时,如果将某些列设置为关联其它表的外键,那么如果对其进行增加.修改操作时,其关联表若没有相匹配的记录则报错,或者在对其关联表进行删除时,也会报错,这就是外键约束的作用,当然除了外键还有许多 ...
- 基础篇 - SQL 的约束
基础篇 - SQL 的约束 约束 一.实验简介 约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性.唯一性.本节实验将在实践操作中熟悉 MySQL 中的几种约束. 二 ...
- SQL CHECK 约束
SQL CHECK 约束 CHECK 约束用于限制列中的值的范围. 如果对单个列定义 CHECK 约束,那么该列只允许特定的值. 如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限 ...
- SQL UNIQUE 约束
SQL UNIQUE 约束 UNIQUE 约束唯一标识数据库表中的每条记录. UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证. PRIMARY KEY 拥有自动定义的 ...
- SQL数据库约束、默认和规则
数据的完整性 实体完整性 又称为行完整性,即数据库中的所有行都具有一个非空且没有重复的主键值 MSSQL中通过唯一索引.PRIMARY KEY约束.UNIQUE约束.INDENTITY属性等来强制主键 ...
- SQL Server - 约束 CONSTRAINT
总结 约束放置在表中,以下五种约束: NOT NULL 非空约束C 指定的列不允许为空值 UNIQUE 唯一约束U 指定的列中没有重复值,或该表中每一个值或者每一组值都将是唯一的 PRIMARY KE ...
- MySQL笔记(五)MySQL 角色与SQL CHECK约束
MySQL ROLE MySQL 8.0 Reference Manual / Security / MySQL User Account Management / Using Roles ...
随机推荐
- SpringCloud学习笔记(3):使用Feign实现声明式服务调用
简介 Feign是一个声明式的Web Service客户端,它简化了Web服务客户端的编写操作,相对于Ribbon+RestTemplate的方式,开发者只需通过简单的接口和注解来调用HTTP API ...
- 在asp.net core中使用托管服务实现后台任务
在业务场景中经常需要后台服务不停的或定时处理一些任务,这些任务是不需要及时响应请求的. 在 asp.net中会使用windows服务来处理. 在 asp.net core中,可以使用托管服务来实现,托 ...
- 【第十篇】easyui-datagrid排序 (转)
本文体验datagrid的排序. □ 思路 当点击datagrid的标题,视图传递给Controller的Form Data类似这样:page=1&rows=10&sort=Custo ...
- map转java对象
pom依赖: <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons ...
- iOS面试题整理带答案
iOS面试题整理带答案 找工作,面试是避免不了的! 而技术开发面试,问一些技术相关的问题是必须的,最新的技术可能人人都趋之若鹜,但有些原理和基础的也希望都有了解. 这里整理了一些iOS相关 ...
- 由 [SDOI2012]Longge的问题 探讨欧拉函数和莫比乌斯函数的一些性质和关联
本题题解 题目传送门:https://www.luogu.org/problem/P2303 给定一个整数\(n\),求 \[ \sum_{i=1}^n \gcd(n,i) \] 蒟蒻随便yy了一下搞 ...
- Windows下更换MAC地址
使用TMAC软件是最佳方案.官网地址:www.technitium.com
- 07 (OC)* XIB原理和Xib、storyBoard、代码的优缺点
1:可读性 2:可视化界面.立马看到 3:开发速度. 4:复用性 5:维护性差 本质 编译时对xml文件做了如下操作1,读取xml文件,生成所有界面对象,生成所有object(即自定义的control ...
- 使用python发邮件(qq邮箱)
今天打算用QQ邮箱作为示例使用的邮箱,其他邮箱基本操作一样. 第一步:首先获取QQ邮箱授权码 1.进入QQ邮箱首页,点击设置,如图, 2.然后点击账户 3.拉到这个地方,开启POP3/SMTP服务服务 ...
- Spring 梳理 - ContentNegotiatingViewResolver
ContentNegotiatingViewResolver,这个视图解析器允许你用同样的内容数据来呈现不同的view.它支持如下面描述的三种方式: 1)使用扩展名http://localhost:8 ...