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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 一文学透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 – 才能删班级表


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
17天前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
30 4
|
29天前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
1月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
36 1
|
2月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
49 0
在 MySQL 中使用约束
|
4月前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
31 1
|
3月前
|
存储 SQL 关系型数据库
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
MySQL设计规约问题之在数据库设计中,为什么要适当考虑反范式的表设计
|
3月前
|
SQL 存储 数据库
MySQL设计规约问题之如何处理日志类型的表
MySQL设计规约问题之如何处理日志类型的表
|
3月前
|
运维 关系型数据库 MySQL
实时计算 Flink版产品使用问题之在处理MySQL表新增数据记录时,没有正确触发变更事件,该如何解决
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
4月前
|
SQL 关系型数据库 MySQL
ClickHouse(23)ClickHouse集成Mysql表引擎详细解析
ClickHouse的MySQL引擎允许执行`SELECT`查询从远程MySQL服务器。使用`MySQL('host:port', 'database', 'table', 'user', 'password'[,...])`格式连接,支持简单`WHERE`子句在MySQL端处理,复杂条件和`LIMIT`在ClickHouse端执行。不支持`NULL`值,用默认值替换。系列文章涵盖ClickHouse安装、集群搭建、表引擎解析等主题。[链接](https://zhangfeidezhu.com/?p=468)有更多
227 0