MySQL 约束「终于解决」

MySQL 约束「终于解决」* 概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。 * 分类: 1. 主键约束:primary key 2. 非空约束:not null 3. 唯一约束:unique 4. 外键约束

MySQL 约束

  • 概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。
    • 分类:

      1. 主键约束:primary key
      2. 非空约束:not null
      3. 唯一约束:unique
      4. 外键约束:foreign key
    • 非空约束:not null,值不能为null

      1. 创建表时添加约束
        CREATE TABLE stu(
        id INT,
        NAME VARCHAR(20) NOT NULL — name为非空
        );

      2. 创建表完后,添加非空约束
        ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;

      3. 删除name的非空约束
        ALTER TABLE stu MODIFY NAME VARCHAR(20);

    • 唯一约束:unique,值不能重复

      1. 创建表时,添加唯一约束
        CREATE TABLE stu(
        id INT,
        phone_number VARCHAR(20) UNIQUE — 添加了唯一约束

        );

        • 注意mysql中,唯一约束限定的列的值可以有多个null
      2. 删除唯一约束

        ALTER TABLE stu DROP INDEX phone_number;

      3. 在创建表后,添加唯一约束
        ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;

    • 主键约束:primary key。

      1. 注意:

        1. 含义:非空且唯一
        2. 一张表只能有一个字段为主键
        3. 主键就是表中记录的唯一标识
      2. 在创建表时,添加主键约束
        create table stu(
        id int primary key,– 给id添加主键约束
        name varchar(20)
        );

      3. 删除主键
        — 错误 alter table stu modify id int ;
        ALTER TABLE stu DROP PRIMARY KEY;

      4. 创建完表后,添加主键
        ALTER TABLE stu MODIFY id INT PRIMARY KEY;

      5. 自动增长:

        1. 概念:如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长

        2. 在创建表时,添加主键约束,并且完成主键自增长
          create table stu(
          id int primary key auto_increment,– 给id添加主键约束
          name varchar(20)
          );

        3. 删除自动增长
          ALTER TABLE stu MODIFY id INT;

        4. 添加自动增长
          ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;

    • 外键约束:foreign key,让表于表产生关系,从而保证数据的正确性。

      1. 在创建表时,可以添加外键

        • 语法:
          create table 表名(
          ….
          外键列
          constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)
          );
      2. 删除外键
        ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

      3. 创建表之后,添加外键
        ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);

      4. 级联操作

        1. 添加级联操作
          语法:ALTER TABLE 表名 ADD CONSTRAINT 外键名称
          FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE ;
        2. 分类:
          1. 级联更新:ON UPDATE CASCADE
          2. 级联删除:ON DELETE CASCADE

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/7291.html

(0)
上一篇 2023-03-23
下一篇 2023-03-23

相关推荐

  • 利用 Python bytes() 将对象转换为原始字节序列

    利用 Python bytes() 将对象转换为原始字节序列在Python中,bytes()函数是用于表示二进制数据的类。它可以存储二进制数据的序列,使数据更容易读取及处理。bytes()函数可以接收单个字符串、字节数组或数字数组类型作为参数。当传递单个字符串作为参数时,字符串中的每个字符都会被转换成一个字节,形成一个新的bytes对象。通过bytes()函数转换后,Python程序可以更加容易地处理底层操作。

    2023-12-14
    114
  • Python字典的快速值检索方法

    Python字典的快速值检索方法Python字典是一种可变容器,可以存储任意类型的值。每个值都与唯一的键相关联,通过该键可以快速访问该值。Python字典使用哈希表实现,因此,字典中的元素是无序的,但是可以通过键快速访问值。

    2024-02-16
    85
  • Python 32位与64位版本区别

    Python 32位与64位版本区别Python是一种高级别的脚本语言,由于其简单易懂的语法和丰富的标准库而变得非常受欢迎。Python有多种版本,其中32位和64位版本是最受关注的两种版本。本文将从多个方面介绍Python 32位和64位版本的区别。

    2024-04-18
    69
  • Python对指数函数的支持

    Python对指数函数的支持指数函数是高中数学中比较重要的一类函数,在实际应用中也有很广泛的用处。Python作为一门强大且灵活的编程语言,也为我们提供了强大的指数函数支持。本文将介绍Python在指数函数方面的各种应用。

    2024-04-14
    73
  • 如何在Linux上运行Python文件

    如何在Linux上运行Python文件Python是一种常用的编程语言,尤其在数据科学、人工智能等领域中应用广泛。对于Linux操作系统的用户而言,运行Python文件也是常见的操作之一。下面将从多个方面对如何在Linux上运行Python文件进行详细阐述。

    2024-05-16
    61
  • 华为云dws数据库_华为自研数据库

    华为云dws数据库_华为自研数据库摘要:高斯Redis,计数的最佳选择! 本文分享自华为云社区《华为云PB级数据库GaussDB(for Redis)揭秘第八期:用高斯 Redis 进行计数》,原文作者:心机胖。 一、背景 当我们打…

    2023-04-14
    153
  • sql 中各种各样的函数是什么_sql常用的五个函数

    sql 中各种各样的函数是什么_sql常用的五个函数学习重点 根据用途,函数可以大致分为算术函数、字符串函数、日期函数、转换函聚合函数。 函数的种类很多,无需全都记住,只需要记住具有代表性的函数就可以了,其他的可以在使用时再进行查询。 一、函数的种类

    2023-04-29
    115
  • SQL 入门教程:使用 WHERE 子句

    SQL 入门教程:使用 WHERE 子句目录汇总:SQL 入门教程:面向萌新小白的零基础入门教程 数据库表一般包含大量的数据,很少需要检索表中的所有行。通常只会根据特定操作或报告的需要提取表数据的子集。只检索所需数据需要指定搜索条件(sea

    2023-04-19
    154

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注