当前位置:网站首页>7.13 Day20----MYSQL
7.13 Day20----MYSQL
2022-08-04 05:24:00 【您算哪块小饼干?】
目录
一、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.数据库的冷热备份:
冷备份-停机(关闭数据库服务)后备份-此时服务不可用
热备份-不停机(不关闭数据库服务)备份-此时服务可用
边栏推荐
- 详解八大排序
- 【SemiDrive源码分析】【MailBox核间通信】47 - 分析RPMSG_IPCC_RPC 方式 单次传输的极限大小 及 极限带宽测试
- word 公式编辑器 键入技巧 | 写数学作业必备速查表
- C Expert Programming Chapter 5 Thinking about Linking 5.1 Libraries, Linking and Loading
- SLSA 框架与软件供应链安全防护
- [Evaluation model] Topsis method (pros and cons distance method)
- C专家编程 第4章 令人震惊的事实:数组和指针并不相同 4.2 我的代码为什么无法运行
- The 2022 PMP exam has been delayed, should we be happy or worried?
- [Cocos 3.5.2]开启模型合批
- 【JS】js给对象动态添加、设置、删除属性名和属性值
猜你喜欢
震惊,99.9% 的同学没有真正理解字符串的不可变性
Resolved error: npm WARN config global `--global`, `--local` are deprecated
What is the salary of a software testing student?
sql server如何得到本条记录与上一条记录的差异,即变动值
符号表
嵌入式系统驱动初级【4】——字符设备驱动基础下_并发控制
day13--postman interface test
npm报错Beginning October 4, 2021, all connections to the npm registry - including for package installa
数的划分之动态规划
Typora 使用保姆级教程 | 看这一篇就够了 | 历史版本已被禁用
随机推荐
12、分页插件
2022 software test interview questions The latest ByteDance 50 real interview questions, 15k have been won after brushing, with explanation + Q&A
Landing, the IFC, GFC, FFC concept, layout rules, forming method, use is analysed
如何低成本修bug?测试左移给你答案
【云原生--Kubernetes】Pod资源管理与探针检测
力扣:96.不同的二叉搜索树
处理List<Map<String, String>>类型
Redis common interview questions
【SemiDrive源码分析】【MailBox核间通信】47 - 分析RPMSG_IPCC_RPC 方式 单次传输的极限大小 及 极限带宽测试
Towards Real-Time Multi-Object Tracking(JDE)
npm安装依赖报错npm ERR! code ENOTFOUNDnpm ERR! syscall getaddrinfonpm ERR! errno ENOTFOUND
Dynamic programming of the division of numbers
C专家编程 第4章 令人震惊的事实:数组和指针并不相同 4.3 什么是声明,什么是定义
在被面试官说了无数次后,终于潜下心来整理了一下JVM的类加载器
动态规划总括
渗透测试(PenTest)基础指南
力扣题解8/3
OpenGL绘制圆
触觉智能分享-SSD20X实现升级显示进度条
System design. How to design a spike system (full version transfer)