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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 什么是约束?约束是作用于表中列上的规则,用于限制加入表的数据;约束的存在保证了数据库中数据的正确性、有效性以及完整性。

约束

什么是约束?

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

约束的分类

  • 非空约束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);
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
12月前
|
安全 关系型数据库 MySQL
PHP与MySQL交互:从入门到实践
【9月更文挑战第20天】在数字时代的浪潮中,掌握PHP与MySQL的互动成为了开发动态网站和应用程序的关键。本文将通过简明的语言和实例,引导你理解PHP如何与MySQL数据库进行对话,开启你的编程之旅。我们将从连接数据库开始,逐步深入到执行查询、处理结果,以及应对常见的挑战。无论你是初学者还是希望提升技能的开发者,这篇文章都将为你提供实用的知识和技巧。让我们一起探索PHP与MySQL交互的世界,解锁数据的力量!
|
11天前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
55 11
|
8月前
|
SQL 关系型数据库 MySQL
网安入门之MySQL后端基础
《网安入门之MySQL后端基础》简介: 本文介绍了数据库及MySQL的基础知识,涵盖数据库的概念、结构与操作。数据库是组织化存储数据的集合,通过表、列、行等结构实现高效管理。MySQL作为开源的关系型数据库管理系统,广泛应用于Web开发。文中详细讲解了MySQL的基本操作,如增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)等语句的使用方法,并介绍了数据库事务的ACID特性。此外,还探讨了SQL注入攻击的风险及防范措施,强调了预处理语句的重要性。最后,简述了PHP中mysqli扩展的使用方法,包括连接数据库、执行查询和关闭连接等步骤。
|
10月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
12月前
|
关系型数据库 MySQL 数据库
MySQL基本操作入门指南
MySQL基本操作入门指南
464 0
|
9月前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
10月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
103 1
|
9月前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
12月前
|
SQL 关系型数据库 MySQL
JavaWeb基础1——MySQL
SQL语句、DDL、DML、DQL(分组查询、子查询等)、Navicat、约束、 一对多等数据库设计、多表查询(联合查询/连接查询)、事务、函数
JavaWeb基础1——MySQL
|
11月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
151 4

推荐镜像

更多