IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 约束(constraint) -> 正文阅读

[大数据]约束(constraint)

? ? ? ? 约束是为了使表中的数据有效。常见的约束有:非空约束(not null)、唯一性约束(unique)、主键约束(primary key,简称PK)、外键约束(foreign key,简称FK)、检查约束(oracle中才可用)。

一,非空约束

? ? ? ? 约束的字段不能为NULL。可以直接在创表时加上not null:

? ? ? ? create table student (age int,name varchar(4) not null);

? ? ? ? 创建表后插入数据,如果是没有定义name只定义了年龄,那么不会有这行数据插入。相反,如果定义了name而没有age,数据可以成功插入,age为NULL。

Notations:可以将所有的sql语句写到一个.sql脚本文件中,然后source 路径运行脚本文件,相当于运行了所有的sql语句。

二,唯一性约束

? ? ? ? uniqe约束的字段不能重复,但是可以为NULL。如果重复保错:Duplicate entry xxx?for key xxx。使用:直接在创表时在字段后加上unique。

? ? ? ? 联合唯一性:指两个字段联合起来具有唯一性(不是每个字段后面加unique,那是每个字段都唯一)。创表方式:

? ? ? ? create table user(id int,name varchar(10),unique(id,name));

? ? ? ? 这种约束叫做表级约束。

Notations:

(1)not null 没有表级约束

(2)not null 和unique联合使用:直接在建表的时候在字段后同时加上not null 和unique。在mysql中,如果一个字段同时被这两个修饰,自动变成主键字段(在oracle中不是这样)。

三、主键约束

? ? ? ? 主键约束中有:1,主键字段:该字段上有主键约束;2,主键值:主键字段的字面值。主键的定义:每一行记录的唯一标识

Notations:主键值相当于一行记录的身份证号。每张表都应该有主键,没有主键该表无效。两行记录可能数据一样,但主键不同就是不同的记录。

? ? ? ? 主键的特征:not null+unique(不能为空,不能重复)。

? ? ? ? 添加主键约束:

????????????????create table user(id int primary key,name varchar(255));

? ? ? ? 或者:

? ? ? ? ? ? ? ? create table user(id int,name varchar(255),primary key(id));

? ? ? ? 复合主键(开发中不建议使用):

????????????????create table user(id int,name varchar(255),primary key(id,name));

? ? ? ? 主键只能在一张表中有一个。建议添加成主键的类型:int,char。不建议使用varchar这种变长的。

3.1 自然主键

? ? ? ? 主键是一个自然数,和业务没关系。

3.2 业务主键

? ? ? ? 主键和业务相关。如:银行卡账号

Notations:

(1)自然主键用的较多,因为其不受业务变化影响。

(2)auto_increment自动维护主键:

? ? ? ? create table user (id int unsigned primary key auto_increment,

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? name varchar(255));

? ? ? ? 会自动生成从1递增的主键id。

四,外键约束

? ? ? ? 相关术语:外键字段,外键值。

? ? ? ? 如上表格,数据冗余度较高。可以把classno,classname存入一张班级表,把no,name存入另一张学生表,节省了空间,但是两张表没有关系。那么可以将classno加入到学生表中,但是在学生表中classno没有约束的话,可能会出错。为了保证classno中的值都是100或101,需要给其添加外键约束,classno就是外键字段。

? ? ? ? 给classno添加约束,让它去引用班级表中的classno字段。被引的班级表就称为父表。要注意它和子表学生表的顺序:

? ? ? ? 删除表:先删子表,再删父表;

? ? ? ? 创建表:先创父表,再创子表;

? ? ? ? 删除数据:先删子,再删父;

? ? ? ? 插入数据:先插父,再插子;

? ? ? ? 外键使用举例:
????????create table class (
????????class_no int primary key,
????????class_name varchar(255));
????????create table student(
????????no int unsigned auto_increment,
????????name varchar(255),
????????class int,
????????primary key(no),
????????foreign key(class) references class(class_no);

????????添加了外键约束后,student中的class只能为class表中的class_no的值,不能是其他值。

Notations:

(1)父表中被引用的字段至少得有唯一性(unique)。

(2)外键值可以为NULL。?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-09-30 00:59:31  更:2022-09-30 01:01:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年4日历 -2025/4/30 1:30:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码