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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 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 – 才能删班级表


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
97 11
|
11月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
关系型数据库 MySQL 数据库
数据迁移脚本优化过程:从 MySQL 到 Django 模型表
在大规模的数据迁移过程中,性能问题往往是开发者面临的主要挑战之一。本文将分析一个数据迁移脚本的优化过程,展示如何从 MySQL 数据库迁移数据到 Django 模型表,并探讨优化前后的性能差异。
|
10月前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
11月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
133 1
|
10月前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
12月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
160 4
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
189 1
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
246 0
在 MySQL 中使用约束

热门文章

最新文章

推荐镜像

更多