【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);
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
17天前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
2月前
|
关系型数据库 MySQL 数据库
MySQL基本操作入门指南
MySQL基本操作入门指南
81 0
|
1月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
36 4
|
2月前
|
SQL 关系型数据库 MySQL
JavaWeb基础1——MySQL
SQL语句、DDL、DML、DQL(分组查询、子查询等)、Navicat、约束、 一对多等数据库设计、多表查询(联合查询/连接查询)、事务、函数
JavaWeb基础1——MySQL
|
2月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
2月前
|
SQL 关系型数据库 MySQL
MySQL入门到精通
MySQL入门到精通
|
2月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
48 1
|
3月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
59 0
在 MySQL 中使用约束
|
4月前
|
SQL 关系型数据库 MySQL
「Python入门」python操作MySQL和SqlServer
**摘要:** 了解如何使用Python的pymysql模块与MySQL数据库交互。首先,通过`pip install pymysql`安装模块。pymysql提供与MySQL的连接功能,例如创建数据库连接、执行SQL查询。在设置好MySQL环境后,使用`pymysql.connect()`建立连接,并通过游标执行SQL(如用户登录验证)。注意防止SQL注入,使用参数化查询。增删改操作需调用`conn.commit()`来保存更改。pymssql模块类似,但导入和连接对象创建略有不同。
61 0
「Python入门」python操作MySQL和SqlServer