--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 六种约束的更多相关文章

  1. SQL PRIMARY KEY 约束\SQL FOREIGN KEY 约束\SQL CHECK 约束

    SQL PRIMARY KEY 约束 PRIMARY KEY 约束唯一标识数据库表中的每条记录. 主键必须包含唯一的值. 主键列不能包含 NULL 值. 每个表都应该有一个主键,并且每个表只能有一个主 ...

  2. SQL CREATE TABLE 语句\SQL 约束 (Constraints)\SQL NOT NULL 约束\SQL UNIQUE 约束

    CREATE TABLE 语句 CREATE TABLE 语句用于创建数据库中的表. SQL CREATE TABLE 语法 CREATE TABLE 表名称 ( 列名称1 数据类型, 列名称2 数据 ...

  3. 扩展Exception,增加判断Exception是否为SQL引用约束异常方法!

    在设计数据表时,如果将某些列设置为关联其它表的外键,那么如果对其进行增加.修改操作时,其关联表若没有相匹配的记录则报错,或者在对其关联表进行删除时,也会报错,这就是外键约束的作用,当然除了外键还有许多 ...

  4. 基础篇 - SQL 的约束

    基础篇 - SQL 的约束       约束 一.实验简介 约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性.唯一性.本节实验将在实践操作中熟悉 MySQL 中的几种约束. 二 ...

  5. SQL CHECK 约束

    SQL CHECK 约束 CHECK 约束用于限制列中的值的范围. 如果对单个列定义 CHECK 约束,那么该列只允许特定的值. 如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限 ...

  6. SQL UNIQUE 约束

    SQL UNIQUE 约束 UNIQUE 约束唯一标识数据库表中的每条记录. UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证. PRIMARY KEY 拥有自动定义的 ...

  7. SQL数据库约束、默认和规则

    数据的完整性 实体完整性 又称为行完整性,即数据库中的所有行都具有一个非空且没有重复的主键值 MSSQL中通过唯一索引.PRIMARY KEY约束.UNIQUE约束.INDENTITY属性等来强制主键 ...

  8. SQL Server - 约束 CONSTRAINT

    总结 约束放置在表中,以下五种约束: NOT NULL 非空约束C 指定的列不允许为空值 UNIQUE 唯一约束U 指定的列中没有重复值,或该表中每一个值或者每一组值都将是唯一的 PRIMARY KE ...

  9. MySQL笔记(五)MySQL 角色与SQL CHECK约束

    MySQL ROLE MySQL 8.0 Reference Manual  /  Security  /  MySQL User Account Management  /  Using Roles ...

随机推荐

  1. springcloud(四):应用配置中心config的安全设置

    springcloud应用配置中心config的安全设置 在springcloud应用开发中,为了方便在线管理我们的配置文件,通常会配一个配置中心config-server,这里托管着应用的一些配置文 ...

  2. 高级部分_委托、Lambda表达式、事件

    委托 (1)把方法当作参数来传递的话,就要用到委托: (2)委托是一个类型,这个类型可以赋值一个方法的引用. C#使用一个类分为两个阶段,首先定义这个类,告诉编译器这个类由什么字段和方法组成:然后使用 ...

  3. 这可能是国内最全面的char RNN注释

    char RNN代码来源于https://github.com/hzy46/Char-RNN-TensorFlow 前言 本人在学习char RNN的过程中,遇到了很多的问题,但是依然选择一行代码一行 ...

  4. style属性css与javascript对照表

    有时候会用javascript来控制标签的style,但js的style属性写法跟css有点不一样,通常是一个单词的写法不变,单词-单词属性会去掉“-”,再把第二个单词的首字母大写,估计是为了与减法运 ...

  5. Winform中实现ZedGraph曲线图的图像复制到剪切板、打印预览、获取图片并保存、另存为的功能

    场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...

  6. c++异常处理函数

    注意: throw 抛出异常,catch 捕获异常,try 尝试捕获异常 catch 中的参数类型要和throw 抛出的数据类型一致 try{    //可能抛出异常的语句}catch (异常类型1) ...

  7. 005:CSS三大重点之三:定位

    目录 1:定位模式和边偏移 2:定位模式 静态定位 相对定位:移动位置:脱标.占位置 绝对定位:脱标.占有位置. 拼爹型 子绝父相 固定定位:脱标.占有位置. 3:定位模式转换 3:z-index 前 ...

  8. maven的mirror和repository加载顺序

    一.概述 maven的settings.xml文件里面有proxy.server.repository.mirror的配置,在配置仓库地址的时候容易混淆 proxy是服务器不能直接访问外网时需要设置的 ...

  9. [Leetcode][动态规划] 第935题 骑士拨号器

    一.题目描述 国际象棋中的骑士可以按下图所示进行移动:                           我们将 “骑士” 放在电话拨号盘的任意数字键(如上图所示)上,接下来,骑士将会跳 N-1 步 ...

  10. MySQL性能优化以及常用命令

    1.将查询操作SELECT中WHERE条件后面和排序字段建立索引 2.按需查询,需要哪个字段就查哪个字段,禁止使用"SELECT * " 3.数据库引擎最好选用InnoDB,少用M ...