一文学透MySQL表的创建和约束

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 一文学透MySQL表的创建和约束

一、数据库的建立和销毁


建立数据库:


create database [if not exists] 数据库名 [default charset 字符集]

1

tips: 中括号[]里面的内容可以省略不写


加上if not exists的含义是:如果不存在此数据库就会创建

default charset 字符集是创建数据库的时候设置字符集

销毁数据库:


drop database [if exists] 数据库名

1

tips: 可省略部分的含义同上


二、表的建立和销毁


1、表的建立


语法:


create table [if not exists] 表名(
  字段名  数据类型  [约束],
    字段名  数据类型  [约束],
    ...(最后一个字段不能加逗号)
)

1.1、命名规则


表名通常以t_开头

关键字段通常以表名缩写_开头

MySQL不区分大小写,不能使用关键字命名,多个部分之间用下划线连接


1.2、数据类型


需要掌握的数据类型:


整数:int、integer、bigint

小数:decimal

字符串:varchar

枚举:enum

日期:datatime

使用建议:


当字段数字一定大于0并且不会进行减运算时可以使用无符号数unsigned,通常不建议

float和double存在精度问题,后续mysql将不再支持

char和verchar在保存多个字符时底层实现是一致的,只是占用空间的模式不同,不建议使用char,因为有可能浪费空间

timestamp上限太低,date和time不实用,所以日期建议使用datetime

2、表约束概念


2.1、约束预览


约束 解释 说明

primary key 主键 用来标志一列为主键列

not null 非空 约束该列值不允许为空

unique 唯一 约束该列值不允许重复

default 默认 给该列设置默认值

foreign key 外键 标志一列为外键值

check 检查约束 MySQL不支持


2.2、特点及作用


主键

作用:可以作为唯一标识具体锁定某行数据

特点:非空且唯一

一张表至多有一个主键列

非空

特点:值不能为null,必须设定

唯一

特点:值可以为null,并且可以存在多个null,该约束只对已经存在的值有效

非空约束+唯一约束 不等同于 主键约束

默认

特点:如果该列未显式赋值,则使用默认值存放

语法: default(值)

外键的使用放在下面具体讲解


3、表约束具体使用


3.1、列级约束


直接将约束定义到在列的声明里

使用示例:


-- id、姓名、年龄、性别、身高、生日
create table if not exists t_person(
  p_id int primary key,-- 主键
  p_name varchar(50) unique not null,-- 唯一+非空
  age tinyint unsigned not null,-- 非空 无符号数  0-255
  sex enum('男','女','奥特曼') default '奥特曼',-- 默认
  height decimal(4,1), -- 总共有4位,小数点占1位:000.0
  birthday datetime
)


3.2、表级约束


将约束单独定义在所有列的下方,not null和default没有表级约束

语法:[constraint 自定义约束名] 约束类型(字段名)

使用示例:


create table if not exists t_person(
  p_id int,-- 主键
  p_name varchar(50) not null,-- 唯一+非空
  age tinyint unsigned not null,-- 非空 无符号数  0-255
  sex enum('男','女','奥特曼') default '奥特曼',-- 默认
  height decimal(4,1), -- 总共有4位,小数点占1位:000.0
  birthday datetime,
  -- 表级约束
  primary key(p_id),-- 给p_id添加主键约束
  constraint un_name unique(p_name)-- 给p_name添加唯一约束
)

3.3、外键约束


作用:用来表示两张表之间的联系,必须结合另一张表使用


特点:

连接的必须是另一张表的主键或者唯一列

外键列的值不可自定义,必须来自另一张表与之关联的列中已经存在的值

值可以为null,不唯一

必须用表级约束创建


语法:

foreign key(字段名) references 其他表名(其他表的连接字段名)

使用:

建表顺序:先建没有外键的表,再建有外键的表

删表顺序:先删有外键的,再删没外键的

外键列的数据类型必须与所连接的列一致


使用示例:


-- 班级表:id,班级名
create table t_class(
  c_id  int PRIMARY KEY,
  c_name varchar(20) not null
)
-- 学生表:id,姓名,所属班级id
create table t_student(
  s_id int PRIMARY KEY,
  s_name varchar(20) not null,
  c_id int not null ,
  -- 表级约束
  FOREIGN KEY(c_id) REFERENCES t_class(c_id)
)


4、表的销毁


语法:

drop table [if exists] 表名


注意事项:

在3.3外键约束具体使用中对于有外键的表,要先删除有外键的表,再删除没有外键的表

drop table t_student – 先删学生表

drop table t_class – 才能删班级表


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
3天前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
2天前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
29天前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
31 1
|
6月前
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
2月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
88 4
|
3月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
69 1
|
4月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
81 0
在 MySQL 中使用约束
|
5月前
|
存储 SQL 关系型数据库
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计