当前位置:网站首页>7.13 Day20----MYSQL

7.13 Day20----MYSQL

2022-08-04 05:24:00 您算哪块小饼干?

目录

一、MYSQL-重点

1. 数据类型:

问题:

2. 约束

3. SQL分类-语法整理(按重要顺序进行排序)

4.连表查询的方式:

5. 关系类型和三范式、反三范式:

6. 事物四大特性和四种隔离级别:

7.锁的种类:

8.死锁、如何防止死锁:

9.索引:

二、MSQL-了解

1.存储引擎的区别:

2.关系型数据库与NoSQL(非关系型)数据库的区别:

3. 视图、存储过程、存储函数、触发器

4.SQL语句优化、数据库优化的思路:

5.数据库的冷热备份:


一、MYSQL-重点

 

1. 数据类型:

     

问题:

1.float和double的区别:

float 4个字节 单精度

double 8个字节 双精度

2.char和varchar的区别:

char支持的长度是0-255.varchar支持的长度是0-65535

char是定长字符串,以空间字符串;varchar是长度是可变的,以时间换空间;char不会动态记录数据长度,varchar会动态记录数据长度,varchar的性能没有char好,因为varchar更节约动态空间

3.char(32)和varchar(32)括号里面的长度是字节还是字符:

Mysql5.0版本以前是字节,假设字符集是UTF-8,一个中文3个字节那么char(32)只能存储10个中文字符

4.用什么类型存储金额:

数据库里面严禁用float和double存储金额有两个解决方案:第一个,用定点数类型decimal存储金额,第二个方案,用长整数类型存储金额到最小单位

5.超长文本(博客,文章)怎么存储:

严禁使用varchar存储超长文本(超过5000),应该改用Blobl类型或者Test类型来存储超长文本,并且应该把超长文本的字段单独分离出去,与主表形成关联,防止超长文本中超长字段影响主表查询效率

6.二进制文件(图片、音频、视频)怎么存储:

MYSQL数据库可以存储二进制文件用Binary类型,但是性能非常差,把二进制数据存储在文件里面,然后在数据库里面记录文件的路径

7.MYSQL的整型支持无符号,使用关键字UNSIGNED

   age tinyint                     --age字段的取值范围是-128到127

   age tinyint unsigned       --age字段的取值范围是0-255

2. 约束

1.非空约束

NOT NULL: 用于控制字段的内容一定不能为空(NULL)。

2.唯一约束 (自动添加唯一索引)

UNIQUE: 控件字段内容不能重复,一个表允许有多个 Unique 约束。

3.主键约束 (自动添加聚簇索引)

PRIMARY KEY: 也是用于控件字段内容不能重复,但它在一个表只允许出现一个。

4.外键约束

FOREIGN KEY: 用于预防破坏表之间连接的动作,也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。

5.检测约束 (MySQL数据库没有检查约束)

CHECK: 用于控制字段的值范围。

3. SQL分类-语法整理(按重要顺序进行排序)

1.数据查询语言DQL(Data Query Language)

SELECT,FROM,WHERE,GROUP BY,ORDER BY

这个较为好理解 即查询操作,以select关键字。各种简单查询,连接查询等 都属于DQL。

2.数据操纵语言DML(Data Manipulation Language)

INSERT,UPDATE,DELETE

主要为以上操作 即对数据进行操作的,对应上面所说的查询操作 DQL与DML共同构建了多数初级程序员常用的增删改查操作。而查询是较为特殊的一种 被划分到DQL中。

3.事务控制功能TCL(Transaction Control Language)

COMMIT,ROLLBACK

用于操作事务,以及事务的提交和回滚操作

4.数据定义语言DDL(Data Ddefinition Language)

CREATE,DROP,ALTER

主要为以上操作 即对逻辑结构等有操作的,其中包括表结构,视图和索引。

5.数据控制功能DCL(Data Control Language)

GRANT,REVOKE

主要用来对数据库用户授予或回收访问数据库的某种权限

4.连表查询的方式:

    

5. 关系类型和三范式、反三范式:

数据库表关系:一对一,一对多(多对一),多对多

三范式-一时间换空间(增加关系来减少冗余数据)

反(打破)三范式-以空间换时间(允许适量的冗余数据,减少关系)

(1)第一范式(1NF)

  数据库的每一列都是不可分割的基本数据项,同一列中不可能有多个值,即:实体类的某个属性不能有多个值或者不能有重复的属性(原子性)

(2)第二范式(2NF)

  前提是要满足第一范式,要求数据库表中的每一个实例或行必须可以被唯一的区分,为实现区分通常需要为表加一个列,以存储各个实例的唯一标识(不产生局部依赖,每列都完全依赖于主键,一张表只描述一件事)

(3)第三范式(3NF)

  前提是满足第二范式,要求一个数据库表中不包含已经在其他表中已经包含的非主关键字信息(就是要使用外键的方式将其关联过来,不产生传递依赖,所有的列都直接依赖于主键,同时使用外键关联,外键都来源于其他表的主键)

(4)反三范式

  反三范式是为了追求性能,因为3NF提出的目的是为了降低冗余,减少不必要的存储,然而随着存储设备的降价以及人们对性能要求的不断提高,提出了反三范式的概念

6. 事物四大特性和四种隔离级别:

7.锁的种类:

8.死锁、如何防止死锁:

9.索引:

二、MSQL-了解

1.存储引擎的区别:

     InnoDb

     Mylsam

     Memory

2.关系型数据库与NoSQL(非关系型)数据库的区别:

    主流的关系型数据库:MySQL Oracle

    主流的NoSQL数据库:Redis

    MySQL和Redis的关系不是谁能替代谁,而是在数据量非常大,数据库并发操作非常频繁的情况下,可以通过Redis来搭建缓存服务器分担MySQL的压力

3. 视图、存储过程、存储函数、触发器

4.SQL语句优化、数据库优化的思路:

5.数据库的冷热备份:

    冷备份-停机(关闭数据库服务)后备份-此时服务不可用

   热备份-不停机(不关闭数据库服务)备份-此时服务可用

原网站

版权声明
本文为[您算哪块小饼干?]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_63771774/article/details/125756385