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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 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引擎

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


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
3月前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
112 11
|
6月前
|
存储 SQL 关系型数据库
MySQL存储引擎简介
在选择相应的存储引擎时,需要充分考虑实际业务场景、性能需求和数据一致性要求,从而为数据管理提供最佳支持。
332 17
|
11月前
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
1793 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
12月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
7月前
|
存储 缓存 关系型数据库
MySQL为什么需要主键
本文介绍了MySQL中主键的重要性及最佳实践。主键用于唯一标识表中的每一行,其值必须唯一且不允许为空。主键有助于简化更新和删除操作,避免影响无关行。推荐使用与业务无关的自增ID作为Innodb表的主键,以优化存储结构、减少碎片并提高性能。此外,文章还提到不更新、不重用主键值以及避免使用可能变更的字段(如邮箱)作为主键的良好习惯。最后强调了紧凑索引结构对查询效率的关键作用。
211 0
MySQL为什么需要主键
|
8月前
|
存储 关系型数据库 MySQL
MYSQL支持的存储引擎有哪些, 有什么区别
MYSQL存储引擎有很多, 常用的就二种 : MyISAM和InnerDB , 者两种存储引擎的区别 ; ● MyISAM支持256TB的数据存储 , InnerDB只支持64TB的数据存储 ● MyISAM 不支持事务 , InnerDB支持事务 ● MyISAM 不支持外键 , InnerDB支持外键
|
11月前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
11月前
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
256 7
|
11月前
|
存储 关系型数据库 MySQL
MySQL主键谁与争锋:MySQL为何钟爱自增主键ID+UUID?
本文深入探讨了在MySQL中使用自增类型主键的优势与局限性。自增主键通过保证数据的有序性和减少索引维护成本,提升了查询和插入性能,简化了数据库管理和维护,并提高了数据一致性。然而,在某些业务场景下,如跨表唯一性需求或分布式系统中,自增主键可能无法满足要求,且存在主键值易预测的安全风险。因此,选择主键类型时需综合考虑业务需求和应用场景。
351 2
|
存储 SQL 关系型数据库
MySQL存储引擎
本文介绍了数据库优化的多个方面,包括选择合适的存储引擎、字段定义原则、避免使用外键和触发器、大文件存储策略、表拆分及字段冗余处理等。强调了从业务层面进行优化的重要性,如通过活动设计减少外部接口调用,以及在高并发场景下的流量控制与预处理措施。文章还提供了具体的SQL优化技巧和表结构优化建议,旨在提高数据库性能和可维护性。
354 1
MySQL存储引擎

推荐镜像

更多