数据库-列的完整性约束-概述

引言

我们都知道人以群分 ,但分为 若按照 人类的皮肤分类 黄种人(其实是西方人定义)我们虽然不承认也不否定 ,黑皮肤 ,棕色人种(在南太平洋和西太)白种人 排名你懂的 这好像是枚举类型

emm 尴尬

当然因为不冲突也可能存在于混血。 我们应该可以用 ID表示因环境而变化的人类

ID=1 黄种人 ID=2 黑皮肤 ID=3 棕色人种 ID=4 白种人

sql 复制代码
create database demo;
use demo;

create table demos(id int ,name varchar(64), compId int );  # compId  肤色分类 ID=1 黄种人 ,ID=2 黑皮肤 ID=3 棕色人种 ID=4 白种人   
 #插入数据

 insert into demos values (1,'张三',1);
  insert into demos values (2,'张三',2);
 insert into demos values (3,'张三',3);
  insert into demos values (4,'张三',4);

看这个 例子你能在哪个地方存在有问题 ?

再来一个问题 我们应该为什么需要身份证?

是不是非常好找人? 编号是最快速 因为底层利用哈希值找到对应的人的个人信息

也就是说将 公民身份证 编号 - 哈希值 通过哈希值找到对应的个人信息

而不是通过身份证号码 找到 具体的查看哈希表非常生动的例子,

这跟列的完整性约束有啥关联的嘛 你想想假设 张三 他有多个叫张三 的? 是不是需要 一个居民身份证? 这个身份证就是列的完整性约束 约束 的是身份证必须唯一编号 若张三突然想跑阿美莉卡国跟金牌讲师混,若有申请了加入阿美莉卡国籍 那他应该放弃中国国籍 那么问题来啦 全中国哪知道是那个张三 假设有10万个 叫张三按照上面的公民身份证 姓名 - 哈希值 通过哈希值找到对应的个人信息 而且报道有可能是 另外一个地址 那么 你觉得会不会误把另外一个人也叫张三 删除 无论怎么样这种方式低下 并且也无法确认是张三 , 其实古人的智慧可是 厉害 在于 虽然画的不咋地但描述信息全 已经获取到他家地址
所以现代的文明 是基于古代的智慧 并且加以改良罢了 好的 唠,这么多了 有没有收获呢 嘿嘿

当然 列的完整性约束 有非常多种

  1. NOT NULL:确保列中不能有NULL值。这意味着在插入或更新记录时,该列必须有值。

    sql 复制代码
    CREATE TABLE example (
        id INT NOT NULL,
        name VARCHAR(255) NOT NULL
    );
  2. DEFAULT:为列提供一个默认值,当插入记录时如果没有为该列提供值,则自动使用这个默认值。

    sql 复制代码
    CREATE TABLE example (
        id INT NOT NULL,
        name VARCHAR(255) NOT NULL,
        created_at DATETIME DEFAULT CURRENT_TIMESTAMP
    );
  3. UNIQUE:确保列中的所有值都是唯一的,没有重复的值。

    sql 复制代码
    CREATE TABLE example (
        id INT NOT NULL UNIQUE,
        email VARCHAR(255) UNIQUE
    );
  4. PRIMARY KEY:用于唯一标识表中的每一行。一个表只能有一个主键,主键列不能有NULL值。

    sql 复制代码
    CREATE TABLE example (
        id INT NOT NULL,
        name VARCHAR(255),
        PRIMARY KEY (id)
    );
  5. AUTO_INCREMENT:通常与主键一起使用,自动为每条新记录生成一个唯一的数字。这个数字从1开始,每次插入新记录时自动增加。

    sql 复制代码
    CREATE TABLE example (
        id INT NOT NULL AUTO_INCREMENT,
        name VARCHAR(255),
        PRIMARY KEY (id)
    );
  6. FOREIGN KEY:用于建立两个表之间的关系,确保列中的值必须是另一个表中主键的值。这有助于维护数据的参照完整性。

    sql 复制代码
    CREATE TABLE orders (
        order_id INT NOT NULL,
        customer_id INT,
        PRIMARY KEY (order_id),
        FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
    );
相关推荐
Codeking__16 分钟前
前缀和——中心数组下标
数据结构·算法
爱喝热水的呀哈喽27 分钟前
非线性1无修
算法
花火QWQ1 小时前
图论模板(部分)
c语言·数据结构·c++·算法·图论
Freedom℡1 小时前
Spark,连接MySQL数据库,添加数据,读取数据
数据库·hadoop·spark
Pacify_The_North1 小时前
【进程控制二】进程替换和bash解释器
linux·c语言·开发语言·算法·ubuntu·centos·bash
轮到我狗叫了1 小时前
力扣310.最小高度树(拓扑排序,无向图),力扣.加油站力扣.矩阵置零力扣.二叉树中的最大路径和
算法·leetcode·职场和发展
埃菲尔铁塔_CV算法2 小时前
深度学习驱动下的目标检测技术:原理、算法与应用创新(二)
深度学习·算法·目标检测
wuqingshun3141592 小时前
经典算法 (A/B) mod C
c语言·开发语言·c++·算法·蓝桥杯
白杆杆红伞伞2 小时前
04_决策树
算法·决策树·机器学习
爱coding的橙子2 小时前
算法刷题Day9 5.18:leetcode定长滑动窗口3道题,结束定长滑动窗口,用时1h
算法·leetcode·职场和发展