MySQL六种约束的示例详解(全网最全)

第一步,先介绍约束的概念以及常见的六种约束:

在MySQL中,约束是对表中数据的限制,可以在创建表的过程中定义或者在表创建完成之后添加。六种常见数据库约束包括:

  1. PRIMARY KEY (主键)
  2. FOREIGN KEY(外键)
  3. UNIQUE(唯一)
  4. NOT NULL(非空)
  5. CHECK(检查)
  6. DEFAULT(默认)

主键的作用是唯一标识每张表内每一行数据,一个表只能有一个主键。外键是用来建立表之间关联的,从一张表中创建一个对应另一张表中主键的列即可。唯一约束是保证表中的某个列的值是唯一的,不与其他行重复。非空约束是保证表中某个列不为空。检查约束是保证表中某个列的值符合一定的条件。默认约束是当表中某个列的值未指定时,默认给这一列赋值。

第二步,分别对六种约束进行一一讲解:

主键约束的示例:可以创建一个students表,然后给这个表创建一个id列,然后使用PRIMARY KEY关键词将这个列设置为主键。示例代码:

CREATE TABLE students (
  id INT NOT NULL AUTO_INCREMENT,
  name varchar(255) NOT NULL,
  age INT DEFAULT NULL,
  PRIMARY KEY (id)
);

外键约束的示例:可以创建一个students和一个grades表来演示外键的示例。students表中的id列作为主键,grades表中有一个student_id列来与students表中的id列建立关联关系。示例代码:

CREATE TABLE students (
  id INT NOT NULL AUTO_INCREMENT,
  name varchar(255) NOT NULL,
  age INT DEFAULT NULL,
  PRIMARY KEY (id)
);

CREATE TABLE grades (
  id INT NOT NULL AUTO_INCREMENT,
  class varchar(255) NOT NULL,
  grade INT DEFAULT NULL,
  student_id INT NOT NULL,
  PRIMARY KEY (id),
  FOREIGN KEY (student_id) REFERENCES students(id)
);

唯一约束的示例:可以为students表添加一个unique索引,保证name列的值唯一。示例代码:

CREATE UNIQUE INDEX idx_unique_name ON students (name);

非空约束的示例:在students表中,可以让name列不允许为空。示例代码:

CREATE TABLE students (
  id INT NOT NULL AUTO_INCREMENT,
  name varchar(255) NOT NULL,
  age INT DEFAULT NULL,
  PRIMARY KEY (id)
);

检查约束的示例:在students表中,可以设置age列的值只允许为正整数。示例代码:

CREATE TABLE students (
  id INT NOT NULL AUTO_INCREMENT,
  name varchar(255) NOT NULL,
  age INT DEFAULT NULL,
  CHECK (age > 0),
  PRIMARY KEY (id)
);

默认约束的示例:在students表中,如果不指定age列的值,则将age列的值设置为20。示例代码:

CREATE TABLE students (
  id INT NOT NULL AUTO_INCREMENT,
  name varchar(255) NOT NULL,
  age INT DEFAULT 20,
  PRIMARY KEY (id)
);

第三步,总结:

MySQL的六种约束各有不同的作用和应用场景,这些约束可以保证表中的数据存储的合法性和有效性,也可以使得表与表之间的关系更加紧密。实际开发中,我们根据需求选择合适的约束,并将其应用在相应的列上,以达到更好的数据约束和存储效果。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:MySQL六种约束的示例详解(全网最全) - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • CentOS Linux更改MySQL数据库目录位置具体操作

    下面是 CentOS Linux 更改 MySQL 数据库目录位置的详细操作过程: 1. 确定 MySQL 数据库目录位置 MySQL 默认的数据库目录路径是 /var/lib/mysql 。如果想要更改 MySQL 数据库目录位置,首先需要确定新的目录路径,比如这里我们准备将数据库目录修改为 /data/mysql 。 2. 停止 MySQL 服务 在进行…

    database 2023年5月22日
    00
  • MySQL高级操作指令汇总

    MySQL高级操作指令汇总 MySQL是一种常见的关系型数据库管理系统(RDBMS),它提供了许多高级操作指令,以便进行有效的数据管理和检索。在本篇文章中,我将为您介绍MySQL高级操作指令的一些常见用法和示例说明。 1. 存储过程(Stored Procedure) 存储过程是一个预编译的SQL代码块,可以在MySQL中创建和保存,然后在需要使用时调用。存…

    database 2023年5月22日
    00
  • AngularJs和谷歌Web Toolkit (GWT)的区别

    AngularJS和谷歌Web Toolkit(GWT)虽然都是由谷歌开发的,但是它们在使用方式和应用场景上存在一些不同。下面是它们的区别详细说明。 AngularJS AngularJS是一款由谷歌开发的JavaScript框架,用于Web应用程序开发。它是一个基于MVC(Model View Controller)架构的声明式编程模型,通过所谓的指令定义…

    database 2023年3月27日
    00
  • mysql中提高Order by语句查询效率的两个思路分析

    下面是详细讲解“mysql中提高Order by语句查询效率的两个思路分析”的完整攻略。 一、优化思路一:使用索引 在MySQL中,使用索引可以提高查询效率。对于Order by语句,它的查询过程会根据指定的字段进行排序,因此可以在该字段上建立索引,从而提高查询效率。 示例1:建立索引 假设现在有一个表格,名为students,其中有三个字段:id(主键)、…

    database 2023年5月19日
    00
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)

    oracle导出sql语句的结果集和保存执行的sql语句(深入分析) 在Oracle数据库中,我们可以通过一些简单的操作来导出SQL语句的执行结果,并且可以保存SQL语句的执行过程。下面我将介绍具体的实现步骤和注意事项。 导出SQL语句的结果集 在Oracle SQL Developer中,我们可以通过以下步骤导出SQL语句的结果集: 打开Oracle SQ…

    database 2023年5月21日
    00
  • oracle表空间不足ORA-01653的问题: unable to extend table

    接下来我将为您讲解oracle表空间不足ORA-01653的问题,以下为完整攻略: 1. 什么是ORA-01653错误 在Oracle中,对于一些表的插入、更新或删除操作,可能会出现ORA-01653的错误,该错误提示的信息是”unable to extend table”,具有较为严重的影响。这是由于当前表空间的容量不足,Oracle无法再容纳新的数据而造…

    database 2023年5月21日
    00
  • Redis解决高并发问题

    高并发常见场景 商品抢购秒杀等活动 解决方式 使用Redis 列表结构实现队列数据结构,抢成功的使用 rpush 入队,再使用 lpop 出队。 Redis高并发可能产生的问题 redis宕机了,或者链接不上 解决方法:配置主从复制,配置哨兵模式,一旦发现主机宕机,让下一个从机当做主机。最坏的情况,只能关闭Redis连接,去往数据库连接。但由于数据量大,这样…

    Redis 2023年4月13日
    00
  • MybatisPlusException:Failed to process,Error SQL异常报错的解决办法

    针对”MybatisPlusException: Failed to process, Error SQL异常报错”这种情况,可以采取以下步骤进行解决: 1.查看错误日志及异常信息 MybatisPlusException通常是由于SQL异常导致的,我们可以首先查看错误日志,了解具体的异常信息,判断问题出在哪里。常见的异常信息包括SQL语句错误、数据库表结构…

    database 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部