【JavaWeb入门】:MySQL 约束(五种)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 什么是约束?约束是作用于表中列上的规则,用于限制加入表的数据;约束的存在保证了数据库中数据的正确性、有效性以及完整性。

约束

什么是约束?

  • 约束是作用于表中列上的规则,用于限制加入表的数据;
  • 约束的存在保证了数据库中数据的正确性、有效性以及完整性。

约束的分类

  • 非空约束NOT NULL ,保证列中所有数据不能有 null 值
  • 唯一约束UNIQUE ,保证列中所有数据各不相同
  • 主键约束PRIMARY KEY ,主键是一行数据的唯一标识,要求非空且唯一
  • 默认约束DEFAULT ,保存数据时,未指定值则采用默认值
  • 检查约束CHECK ,保证列中的值满足某一条件(MySQL中没有检查约束)
  • 外键约束FOREIGN KEY ,外键用于让两个表的数据之前建立链接,保证数据的一致性和完整性。

举例子

CREATE TABLE emp (
    -- 员工 id ,设置为主键约束,并且自增长
    id INT PRIMARY KEY auto_increment,
    -- 员工姓名 非空且唯一
    ename VARCHAR(20) NOT NULL UNIQUE,
    -- 入职日期 非空
    joindate DATE NOT NULL,
    -- 工资 非空
    salary DOUBLE(7, 2) NOT NULL,
    -- 奖金 默认为 0
    bonus DOUBLE(7, 2) DEFAULT 0
);

非空约束

概念

  • NOT NULL:非空约束用于保证列中的所有数据不能有 null

语法

添加非空约束:

-- 创建表时添加非空约束:
CREATE TABLE 表名{
    列名 数据类型 NOT NULL,
    ...
};

-- 键完表后添加非空约束:
ALTER TABLE 表名 MODIFY 字段名 数据类型 NOT NULL;

删除非空约束:

ALTER TABLE 表名 MODIFY 字段名 数据类型

唯一约束

概念

  • UNIQUE:唯一约束,保证列中所有数据各不相同(AUTO_INCREMENT:当不指定值时自动增长)

语法

添加唯一约束:

-- 创建表时添加唯一约束
-- 方式一:
CREATE TABLE 表名{
    列名 数据类型 UNIQUE [AUTO_INCREMENT],
    ...
};


-- 方式二:
CREATE TABLE 表名{
    列名 数据类型,
    ...
    [CONSTRAINT][约束名称] UNIQUE(列名)
};


-- 键完表后添加唯一约束:
ALTER TABLE 表名 MODIFY 字段名 数据类型 UNIQUE;

删除唯一约束:

ALTER TABLE 表名 DROP INDEX 字段名;

主键约束

概念

  • PRIMARY KEY:主键是一行数据的唯一标识,要求非空且唯一
  • 一张表只能有一个主键
  • 当某一列是数字类型并且唯一(当作主键约束),此时可以添加自动增长的属性,即auto_increment

语法

添加主键约束:

-- 创建表时添加主键约束
-- 方式一:
CREATE TABLE 表名{
    列名 数据类型 PRIMARY KEY [AUTO_INCREMENT];
    ...
};
-- 方式二:
CREATE TABLE 表名{
    列名 数据类型,
    ...
    [CONSTRAINT][约束名称] PRIMARY KEY(列名)
};
​
-- 建完表后添加主键约束:
ALTER TABLE 表名 ADD PRIMARY KEY(字段名);

删除主键约束:

ALTER TABLE 表名 DROP PRIMARY KEY;

默认约束

概念

  • DEFAULT:保存数据时未指定值则采用默认值

语法

添加默认约束:

-- 创建表时添加默认约束:
CREATE TABLE 表名{
    列名 数据类型  默认值,
    ...
};

-- 建完表后添加默认约束:
ALTER TABLE 表名 ALTER 列名 SET DEFAULT 默认值;

删除默认约束:

ALTER TABLE 表名 ALTER 列名 DROP DEFAULT;

外键约束

概念

  • FOREIGN KEY:外键是用来让两个表的数据之间建立链接,以保证数据的一致性和完整性。

语法

添加外键约束:

-- 创建表时添加外键约束:
CREATE TABLE 表名 {
    列名 数据类型,
    ...
    [CONSTRAINT] [外键名称] FOREIGN KEY(外键列名) REFERENCES 主表(主表列名)
};

-- 键完表后添加外键约束:
ALTER TABLE 表名
ADD CONSTRAINT 外键名 
FOREIGN KEY(外键列名)
REFERENCES 主表(主表列名);

删除外键约束:

ALTER TABLE 表名 DROP FOREIGN KEY 外键名;

举例子

-- 部门表:
CREATE TABLE dept {
    id int primary key auto_increment,
    dep_name varchar(20),
    addr varchar(20)
};

-- 员工表:
CREATE TABLE emp {
    id int primary key auto_increment,
    name varchar(20),
    age int,
    dep_id int,
    
    -- 添加外键(dep_id 关联 dept 表的 id 主键):
    CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES dept(id);
};

-- 添加 2 个部门:
INSERT INTO
    dept(dep_name, addr)
VALUES
    ('研发部', '广州'),
    ('销售部', '上海');

-- 添加员工, dep_id 表示员工所在的部门:
INSERT INTO
    emp (NAME, age, dep_id)
VALUES
    ('张三', 22, 1),
    ('李四', 20, 1),
    ('王五', 18, 2),
    ('赵六', 20, 2),
    ('孙七', 22, 3),
    ('周八', 18, 3);
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
7天前
|
SQL 关系型数据库 MySQL
网安入门之MySQL后端基础
《网安入门之MySQL后端基础》简介: 本文介绍了数据库及MySQL的基础知识,涵盖数据库的概念、结构与操作。数据库是组织化存储数据的集合,通过表、列、行等结构实现高效管理。MySQL作为开源的关系型数据库管理系统,广泛应用于Web开发。文中详细讲解了MySQL的基本操作,如增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)等语句的使用方法,并介绍了数据库事务的ACID特性。此外,还探讨了SQL注入攻击的风险及防范措施,强调了预处理语句的重要性。最后,简述了PHP中mysqli扩展的使用方法,包括连接数据库、执行查询和关闭连接等步骤。
|
2月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
20天前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
4月前
|
关系型数据库 MySQL 数据库
MySQL基本操作入门指南
MySQL基本操作入门指南
149 0
|
19天前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
2月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
40 1
|
3月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
93 4
|
4月前
|
SQL 关系型数据库 MySQL
JavaWeb基础1——MySQL
SQL语句、DDL、DML、DQL(分组查询、子查询等)、Navicat、约束、 一对多等数据库设计、多表查询(联合查询/连接查询)、事务、函数
JavaWeb基础1——MySQL
|
4月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略