MYSQL约束的总结和小练习

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 约束笔记:1:主键约束默认是唯一且非空的2:AUTO_INCREMENT在MYSQL8.0中会将自增主键保存到重做日志中,即使关闭后重启,存储引擎innoDB仍然会根据重做日志初始化计数器内存值。3:设置了外键约束后,如果要删除主表的内容,则需要先把从表的相关内容给删除。4:建表时一般设置not null default '' 或default 0,因为nul这个特殊值不好比较,而且查找效率低。5:外键约束不能跨引擎使用,且mysql中其有一定成本,不适合大并发SQL操作,开发中一般在.

约束笔记:

1:主键约束默认是唯一且非空的

2:AUTO_INCREMENT在MYSQL8.0中会将自增主键保存到重做日志中,即使关闭后重启,存储引擎innoDB仍然会根据重做日志初始化计数器内存值。

3:设置了外键约束后,如果要删除主表的内容,则需要先把从表的相关内容给删除。

4:建表时一般设置not null default '' 或default 0,因为nul这个特殊值不好比较,而且查找效率低。

5:外键约束不能跨引擎使用,且mysql中其有一定成本,不适合大并发SQL操作,开发中一般在应用层解决外键约束

6:对于外键约束最好采用ON UPDATE CASCADE ON DELETE RESTRICT的方式(约束等级默认为RESTRICT)

#练习一
 CREATE DATABASE test04_emp;
 USE test04_emp;
 CREATE TABLE emp2(
id INT,
emp_name VARCHAR(15)
 );
 CREATE TABLE dept2(
id INT,
dept_name VARCHAR(15) 
 );
 #1:向表emp2的id列中添加PRIMARY KEY约束
 ALTER TABLE emp2
 ADD PRIMARY KEY(id);
 DESC emp2;
 #2:向dept2的id列中添加RIMARY KEY约束
 ALTER TABLE dept2
 ADD PRIMARY KEY(id);
 #3:向emp2表中添加dept_id,并在其中定义FOREIGN KEY约束,与之相关联的列是dept2表中的id列
 ALTER TABLE emp2
 ADD dept_id INT;
 ALTER TABLE emp2
 ADD CONSTRAINT FOREIGN KEY (dept_id) REFERENCES dept2(id);
#练习二
USE test01_library;
DESC books;
#1:
ALTER TABLE books
MODIFY id INT PRIMARY KEY AUTO_INCREMENT;
#2:
ALTER TABLE books
MODIFY NAME VARCHAR(50) NOT NULL;
#3:
ALTER TABLE books
MODIFY `authors` VARCHAR(100) NOT NULL;
#4:
ALTER TABLE books
MODIFY price FLOAT NOT NULL;
#5:
ALTER TABLE books
MODIFY pubdate YEAR NOT NULL;
#6:
ALTER TABLE books
MODIFY NUM INT(11) NOT NULL;
#练习三
#1:创建数据库test04_company
CREATE DATABASE IF NOT EXISTS tes04_company CHARACTER SET 'utf8';
#2:创建offices和employees表
CREATE TABLE IF NOT EXISTS offices(
officeCode INT(10) PRIMARY KEY,
city VARCHAR(50) NOT NULL,
address VARCHAR(50),
country VARCHAR(50) NOT NULL,
postalCode VARCHAR(15) UNIQUE
);
DESC offices;
CREATE TABLE employees(
employeeNumber INT(11) PRIMARY KEY AUTO_INCREMENT,
lastName VARCHAR(50) NOT NULL,
firstName VARCHAR(50) NOT NULL,
mobile VARCHAR(25) UNIQUE,
officeCode INT(10) NOT NULL,
jobTitle VARCHAR(50) NOT NULL,
birth DATETIME NOT NULL,
note VARCHAR(255),
sex VARCHAR(5),
CONSTRAINT fk_emp_offcode FOREIGN KEY (officeCode) REFERENCES offices(officeCode)
);
#3:将表employees的mobile字段修改到officeCode字段后边
ALTER TABLE employees
MODIFY mobile VARCHAR(25) AFTER officeCode;
#4:将表employees的birth字段改名为employee_birth
ALTER TABLE employees
CHANGE birth employee_birth DATETIME;
#5:修改sex字段,数据类型为CHAR(1),非空约束
ALTER TABLE employees
MODIFY sex CHAR(1) NOT NULL;
#6:删除字段note
ALTER TABLE employees
DROP COLUMN note;
#7:增加字段名favoriate_activity,数据类型为VARCHAR(100)
ALTER TABLE employees
ADD favoriate_activity VARCHAR(100);
#8:将表employees名称改为employees_info
RENAME TABLE employees 
TO employees_info;

image.gif

学习随笔,有何不当或有更佳方案,欢迎朋友们在评论区讨论。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
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约束语法
|
19天前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
2月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
40 1
|
3月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
93 4
|
4月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
79 1
|
5月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
88 0
在 MySQL 中使用约束
|
7月前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
47 1
|
7月前
|
关系型数据库 MySQL 数据挖掘
MySQL窗口函数详解(概念+练习+实战)
MySQL窗口函数详解(概念+练习+实战)
1323 1