Mysql表创建,约束,主键,存储引擎的使用

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 1.约束概述约束的作用就是保证表中的数据有效分类:非空约束 not null(表中数据不能为NULL)唯一性约束 unique (约束的字段不能重复,但是可以为NULL,也就是NULL可以重复)主键约束 primary key (主键不能为NULL,同时不可以重复)外键约束 foreign key检查约束 check(Mysql不支持)联合唯一性:🎈


1.约束概述


约束的作用就是保证表中的数据有效


分类:


非空约束 not null(表中数据不能为NULL)

唯一性约束 unique (约束的字段不能重复,但是可以为NULL,也就是NULL可以重复)

主键约束 primary key (主键不能为NULL,同时不可以重复)

外键约束 foreign key

检查约束 check(Mysql不支持)

联合唯一性:🎈


设定两个字段联合起来具有唯一性的方法:(设置name和email联合唯一性限制)


mysql> create table vip(
    -> id int,
    -> name varchar(30),
    -> email varchar(30),
    -> unique(name,email)
    -> );
Query OK, 0 rows affected (0.13 sec)


注意:在Mysql中,如果一个字段同时被not null和unique约束,则该字段自动变为主键字段😊

联合主键约束:🙌(id和name联合起来做主键,复合主键)


mysql> create table vip(
    -> id int,
    -> name varchar(30),
    -> email varchar(100),
    -> primary key(id,name)
    -> );
Query OK, 0 rows affected (0.06 sec)


实际开发中不建议使用复合主键🎶主键值建议使用int,bigint,char类型,且主键值一般都是定长的


注意:对于一张表来说只要有主键和unique约束的,自动添加索引😶‍🌫️


2.外键的妙用


使用外键可以减少数据表的冗余且使之满足某一范式,但同时连接查询也会降低查询的效率🙌


使用实例:


其中cno字段是class表的classno字段的一个外键


mysql> create table stu(
    -> no int primary key auto_increment,
    -> name varchar(50),
    -> cno int,
    -> foreign key(cno) references class(classno)
    -> );


注意:外键中引用的其他表的字段不一定是要主键,但是一定要有unique约束🎈


3.存储引擎


存储引擎是Mysql中特有的术语🎈实际上是一个表存储/组织数据的方式


Mysql默认的存储引擎是InnoDB,默认的编码方式是utf-8


目前Mysql所有存储引擎:


mysql> show engines\G
*************************** 1. row ***************************
      Engine: MEMORY
     Support: YES
     Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 2. row ***************************
      Engine: CSV
     Support: YES
     Comment: CSV storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 3. row ***************************
      Engine: MRG_MYISAM
     Support: YES
     Comment: Collection of identical MyISAM tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 4. row ***************************
      Engine: BLACKHOLE
     Support: YES
     Comment: /dev/null storage engine (anything you write to it disappears)
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 5. row ***************************
      Engine: InnoDB
     Support: DEFAULT
     Comment: Supports transactions, row-level locking, and foreign keys
Transactions: YES
          XA: YES
  Savepoints: YES
*************************** 6. row ***************************
      Engine: PERFORMANCE_SCHEMA
     Support: YES
     Comment: Performance Schema
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 7. row ***************************
      Engine: ARCHIVE
     Support: YES
     Comment: Archive storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 8. row ***************************
      Engine: MyISAM
     Support: YES
     Comment: MyISAM storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 9. row ***************************
      Engine: FEDERATED
     Support: NO
     Comment: Federated MySQL storage engine
Transactions: NULL
          XA: NULL
  Savepoints: NULL
9 rows in set (0.00 sec)


MyISAM


MyISAM管理的表具有如下特征:


使用三个文件表示每个类:


格式文件:存储表结构的定义(mytable.frm)

数据文件:存储表行的内容(mytable.MYD)

索引文件:存储表上的索引(mytable.MYI)

优点:可转化为压缩,只读来节省空间🎍


InnoDB


mysql默认的存储引擎,支持事务,支持数据库崩溃后自动恢复机制


非常安全!


特点:


每个InnoDB表在数据库目录中以.frm格式文件表示

InnoDB表空间tablespace被用于存储表的内容

提供一组用来记录事务性活动的日志文件

提供全ACID兼容

在Mysql服务器崩溃后自动恢复

多版本(MVCC)和行级锁定

用COMMIT,SAVEPOINT,及ROLLBACK支持事务处理

支持外键及引用的完整性,包括级联删除和更新

缺点:效率不是很高,不能压缩不能转化为只读,不能很好的节省存储空间❌


MEMORY


特点:


在数据库目录内,每个表均以.frm格式文件进行存储

表数据及索引存储在内存中,一断点就消失(目的:查询快速!)

表级锁机制

不能包含TEXT或HEAP引擎

优缺点:效率最高但是数据不安全


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
12天前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
17天前
|
存储 SQL 关系型数据库
MySQL存储引擎
本文介绍了数据库优化的多个方面,包括选择合适的存储引擎、字段定义原则、避免使用外键和触发器、大文件存储策略、表拆分及字段冗余处理等。强调了从业务层面进行优化的重要性,如通过活动设计减少外部接口调用,以及在高并发场景下的流量控制与预处理措施。文章还提供了具体的SQL优化技巧和表结构优化建议,旨在提高数据库性能和可维护性。
MySQL存储引擎
|
2天前
|
存储 缓存 关系型数据库
【赵渝强老师】MySQL的MyISAM存储引擎
在MySQL5.1版本之前,默认存储引擎为MyISAM。MyISAM管理非事务表,提供高速存储和检索,支持全文搜索。其特点包括不支持事务、表级锁定、读写互阻、仅缓存索引等。适用于读多、写少且对一致性要求不高的场景。示例代码展示了MyISAM存储引擎的基本操作。
|
2天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL的InnoDB存储引擎
InnoDB是MySQL的默认存储引擎,广泛应用于互联网公司。它支持事务、行级锁、外键和高效处理大量数据。InnoDB的主要特性包括解决不可重复读和幻读问题、高并发度、B+树索引等。其存储结构分为逻辑和物理两部分,内存结构类似Oracle的SGA和PGA,线程结构包括主线程、I/O线程和其他辅助线程。
【赵渝强老师】MySQL的InnoDB存储引擎
|
2天前
|
存储 关系型数据库 MySQL
【赵渝强老师】MySQL的Memory存储引擎
MySQL 的存储引擎层负责数据的存储和提取,支持多种存储引擎,如 InnoDB、MyISAM 和 Memory。InnoDB 是最常用的存储引擎,从 MySQL 5.5.5 版本起成为默认引擎。Memory 存储引擎的数据仅存在于内存中,重启后数据会丢失。示例中创建了使用 Memory 引擎的 test3 表,并展示了数据在重启后消失的过程。
|
1月前
|
存储 SQL 缓存
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
|
1月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
35 4
|
13天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
26 0
|
1月前
|
存储 SQL 关系型数据库
mysql中主键索引和联合索引的原理与区别
本文详细介绍了MySQL中的主键索引和联合索引原理及其区别。主键索引按主键值排序,叶节点仅存储数据区,而索引页则存储索引和指向数据域的指针。联合索引由多个字段组成,遵循最左前缀原则,可提高查询效率。文章还探讨了索引扫描原理、索引失效情况及设计原则,并对比了InnoDB与MyISAM存储引擎中聚簇索引和非聚簇索引的特点。对于优化MySQL性能具有参考价值。
|
2月前
|
存储 缓存 关系型数据库
MySQL高级篇——存储引擎和索引
MyISAM:不支持外键和事务,表锁不适合高并发,只缓存索引,内存要求低,查询快MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务、行级锁、外键,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。5.5之前默认的存储引擎优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高表名.frm 存储表结构;表名.MYD 存储数据 (MYData);
MySQL高级篇——存储引擎和索引

推荐镜像

更多