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

本文涉及的产品
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 – 才能删班级表


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
运维 DataWorks 关系型数据库
DataWorks产品使用合集之DataWorks还有就是对于mysql中的表已经存在数据了,第一次全量后面增量同步的步骤如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
38 2
|
4天前
|
关系型数据库 MySQL Java
实时计算 Flink版产品使用合集之mysql通过flink cdc同步数据,有没有办法所有表共用一个dump线程
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
9 0
|
6天前
|
SQL 关系型数据库 MySQL
MySQL数据库的约束+进阶版新增与查询-2
MySQL数据库的约束+进阶版新增与查询
16 1
|
6天前
|
关系型数据库 MySQL 测试技术
MySQL数据库的约束+进阶版新增与查询-1
MySQL数据库的约束+进阶版新增与查询
17 1
|
6天前
|
SQL 存储 关系型数据库
【MySQL】DDL的表操作详解:创建&查询&修改&删除
【MySQL】DDL的表操作详解:创建&查询&修改&删除
|
6天前
|
存储 SQL 关系型数据库
mysql查询数据库表大小怎么操作
mysql查询数据库表大小怎么操作
|
6天前
|
关系型数据库 MySQL 数据库
【MySQL】:约束全解析
【MySQL】:约束全解析
26 0
|
6天前
|
存储 SQL 关系型数据库
MySQL表的增删改查---多表查询和联合查询
MySQL表的增删改查---多表查询和联合查询
|
6天前
|
NoSQL 关系型数据库 MySQL
【MySQL探索之旅】MySQL数据表的增删查改——约束
【MySQL探索之旅】MySQL数据表的增删查改——约束
|
6天前
|
存储 关系型数据库 MySQL
{MySQL} 数据库约束& 表的关系& 新增&&删除& 修改& 查询
{MySQL} 数据库约束& 表的关系& 新增&&删除& 修改& 查询
22 0