MySQL之四大引擎、账号管理以及建库认识

目录

一、数据库存储引擎(发动机)

1.1、认识引擎

1.2、查看存储引擎

1.3、引擎常识

1.4、support字段说明 

1.5、四大引擎

二、数据库管理

2.1、元数据库介绍:

2.2、分类:

2.3、增删改查以及使用操作

2.4、权限

三、数据库表管理

3.1、三大范式(面试)

3.2、列段选中的规则

1、优化原则

a、更小(节约空间)

b、简单就好

c、尽量避免NULL

d、用整型值而不是字符串表示IP地址

3.3、基本数据类型

整数

实数(带有小数点)

字符串

text&plob(用得少)

日期类型

选择标识符

四、数据库账号管理

7.5与8.0版本相同:

4.1、查询用户:        

4.2、查看用户常用信息:   

4.3、删除用户

4.4、权限操作

设置权限(Grant)

撒销权限(Revoke)

查看用户权限

7.5与8.0版本不同

五、思维导图总结


一、数据库存储引擎(发动机)

1.1、认识引擎

MySQL中的引擎是指存储引擎,它是用于存储、管理和检索数据的内部组件。不同的存储引擎具有不同的特性和功能,例如MyISAM、InnoDB、MEMORY等。选择合适的存储引擎可以根据应用的需求来提高性能和可靠性。MySQL中的存储引擎可以通过CREATE TABLE语句中的ENGINE选项来指定。

1.2、查看存储引擎

语法方式:show engines

鼠标方式:找到表,右键设计,点击选项第一个

1.3、引擎常识

常用引擎:MyISAM、InnoDB、MEMORY、ARCHIVE

默认引擎:InnoDB

1.4、support字段说明 

DEFAULT(default)===默认的引擎

YES===可以使用

NO===不能使用

1.5、四大引擎

  • MyISAM

适合用于读密集型的应用,即大部分是查询操作而写操作相对较少的情况。它在处理大量的SELECT查询时性能较好,因为它是基于表级锁定的,这意味着在写操作时会锁定整个表,因此并发写操作会受到影响。另外,MyISAM不支持事务和外键约束,因此不适合需要强大事务支持和数据完整性保证的应用。

使用场景:大量查询,很少修改的场景,例如:开发上数据字典、信用参数、数据仓库、日志记录和其他只读或者很少更新的数据。

特点

①强调了快速读取操作------------表锁
②存储限制: 256TG
③事务支持:不支持事务

  • InnoDB

使用场景:

一般事务性,均使用该引擎,用途最广,如果把握不准使用何种引擎,就使用该引擎

特点

修改快,支持事务------行锁
②存储限制: 64TG
③事务支持:支持事务

  • MEMORY(当成视图用)

适合用于对性能要求非常高的应用,因为它将表中的数据存储在内存中,而不是在磁盘上。这意味着对于读取操作,提供非常快速的访问速度。然而,由于数据存储在内存中,因此对于大型数据集来说,内存的消耗可能会成为一个限制因素。

使用场景:由于易失性,可以用于存储在分析中产生的中间表

1. 对读取操作有较高要求的应用,例如缓存或者临时数据存储。
2. 数据量相对较小,并且对数据持久性要求不高的应用。
3. 用于临时表或者数据集合,例如用于复杂查询的中间结果存储。

特点
①所有的数据都保存在内存中,一旦服务器重启,所有memry存储引擎的表数据会消失但是表结构会保存下来

②存储限制:取决于RAM-----RAM:随机存储器、ROM只读存储器
③事务支持:不支持事务

  • ARCHIVE

适合用于需要对大量历史数据进行存档和备份的场景。它主要用于只读的数据存储,对于插入和查询操作有较高的性能,但不支持更新和删除操作。数据压缩能力非常强大,可以大幅减少磁盘空间的占用,因此非常适合用于存储大量历史数据,并且对数据的读取操作相对较少的情况。


使用场景:在日志和数据采集的时候可以使用 

常见的使用场景包括:
1. 数据归档:将历史数据进行归档存储,以便长期保存和备份。
2. 日志存储:对于大量的日志数据,可以使用ARCHIVE存储引擎进行存储,节省磁盘空间。
3. 数据仓库:用于存储大量历史数据,以便进行数据分析和报表生成。

特点
①只允许插入和查询,不允许修改和删除,压缩存储,节约空间,可以实现高并发的插入,支支持在自增ID上建立索引

②archive表比MylSAM表要小大约75%,比支持事务处理的InnoDB表小大约83%

③事务支持:不支持事务

二、数据库管理

2.1、元数据库介绍:

记录MySQL自身的数据库

2.2、分类:

默认数据库:3个

information schema:(放自己建的库)
信息数据库,保存mysql所维护的其他数据库信息

例如:数据库名,数据库的表,表栏的数据类型与访问权限等

mysql:(可能要操作的表)
核心数据库,主要负责存储数据库的用户、权限设置、关键字等

mysql自己需要使用的控制和管理信息。


performance_schema:(用在集群---读写分离)

用于mysql的监控数据的存放

2.3、增删改查以及使用操作


使用库:use 数据库名


创建/增加库:

正常创建:create database

完整创建:create database if not exists 数据库名 default charset utf8 collate utf8_general_ ci;

utf8_general_ ci:设置字符编码以及不区分大小写

鼠标创建:右键


查询所有数据库:show databases

删除数据库:drop databases +数据库名字

2.4、权限

先看用户用那些权限

1、user表(用户层权限)
2、db表(数据库层权限)
3、tables _priv表(表层权限)
4、columns_priv表 (字段层权限) 

三、数据库表管理

3.1、三大范式(面试)


第一范式:列不可再分 (原子性)

例如: 湖南省长沙市岳麓区浪琴湾清水2

(错)第一方式:只设置一个字段address
(对)第二方式:provence省、city市、area区、address具体地址

可能会做统计:哪个省买了多少,哪个城市买了多少(销量)


第二范式:主键约束

例如:

订单项表设计: id、单价、 数量、小计

小计是依托单价和数量算出来的,对于开发人员偷懒,修改是发现数据对不上

第三范式:外键约束

例如:患者id、患者姓名同时存在于一张关联表中

在开发中,想要查询患者信息,要连两个表患者表和医生表

患者表-----绑定了医生的id(偷懒:即存id又存名字-------1对应哈哈哈) 

医生表(1又换成嘿嘿嘿)

最后导致数据不一致

3.2、列段选中的规则

1、优化原则

a、更小(节约空间)


更小通常更快
更小的磁盘空间、内存、CPU缓存
更少的CPU周期

例如:只知道会存男、女,不可能设置成200

b、简单就好


整型比字符串操作代价更小
用时间类型表示日期 (date、datetime等)而不用字符串

c、尽量避免NULL



NULL为列的默认值,但除非确实需要,应尽量避免使用NULL
尽量指定列为NOT NULL,特别是需要建索引的列


查询中包括有NULL的类,MySQL更难优化:

①不利于使用索引

②索引统计更复杂

③值比较,更复杂------想要比对a和b区别中

d、用整型值而不是字符串表示IP地址


INET_ATON()
INET_NTOA()

3.3、基本数据类型

整数

tinyint--------- ------8位(-128~127)
smallint--------- ----16位(-32768~32767)
mediumint----------24位(-8388608-8388607)
int---------------------32位大约正负21亿
bgint -----------------64位

实数(带有小数点)

float -------4个字节

double-----8个字节

 decimal最多允许65个数字
 

例:decimal(5.2); 说明: 5位长度,2位小数精度,如果只是小数部分超出2位,则四舍五入到2位

字符串

char

定长(用不用就是那么大),MySQL根据定义字符串的长度一次分配足够的空间
适用场景:较短的字符串,且所有值接近同一长度,例如:男:女、是:否、YES:NO

一般定义:2、4、8



varchar
比定长类型节约空间
适用场景:字符串的最长长度比评估长度大很多,列的更新较少

缺点:频繁修改,且字符串的长度变化大时,可能出现页分裂
 

text&plob(用得少)

text------------存储字符数据(用于写文章)

分为:

tinytext
smalltext(小)
mediumtext(中)
text
longtext(大/长)

blob----------------存储二进制数据(用于视频、音频、图片)

分为:
tinyblob
smallblob
blob
mediumblob
Iongblob

总:

1.都为存放很大的数据而设计
2.与其他数据不同,都作为独立的对象存储

3.当值太大时,使用外部存储区存储,每行只要使。。。
 

日期类型

datetime:

精度:秒
与时区无关,8个字节存储空间
范围:1001至9999年

timestamp:
保存1970年1月1日午夜以来的秒数
占用4个字节存储空间
范围:1970年至2038年
与时区有关
默认为NOTNULL
通常尽量使用timestamp 

date:yyyy-MM-dd

time:HH:mm:ss

选择标识符

  • 用来进行关联操作
  • 在其他表中作为外键
  • 整型通常是标识列的最好选择

注:区别:虽然查出结果没有区别,但是第二个需要把字符串转成整形,速度慢

  • 相关的表中使用相同的数据类型
  • 尽量避免字符串作为标识列,尤其是随机生成的字符串, (如: UUID)导致insert与select都很慢

插入值被随机写到索引的不同位置,insert慢,容易导致页分裂,磁盘随机读取逻辑上相邻的行被分布在磁盘和内存的不同地方,select 慢
是MySQL查询缓存失效
如果需要存储UUID,则应将“-”去除 

四、数据库账号管理

案例:

项目经理可以看见所有项目表

项目组长可以看见他那个项目的表

普通研发/测试/产品可以用他那个项目的表,同时没有建表删表

7.5与8.0版本相同:

4.1、查询用户:        

SELECT *FROM USER;

4.2、查看用户常用信息:   

     select host,user from user;

user表中host列的值的意义:
%---------匹配所有主机
localhost----------localhost不会被解析成IP地址,直接通过UNIXsocket连接

127.0.0.1-------会通过TCP/IP协议连接,并且只能在本机访问;
::1--------兼容支持ipv6的,表示同ipv4的127.0.0.1


4.3、删除用户

drop user +用户名;

4.4、权限操作


设置权限(Grant)

语法:

grant privileges (操作)on databasename(表名字).tablename(表里面的字段) to username(用户)@'host';

db是一个库的名字  Zs是一个用户   db_xiaoli表#给 Zs用户 赋予 数据库db xiaoli中的表t p1 user 查询权限
grant SELECT on db_xiaolit.t p1 user to zs@'%';#给 Zs用户 赋予 数据库db xiaoli中的表t p1 user 修改权限
grant UPDATE on db_xiaolit p1 user to zs@'%';#给 Zs用户 赋予 数据库db xiaoli中所有表 查询权限
grant SELECT on db_xiaoli.* to zs@'%';#给 Zs用户 赋予 数据库db xiaoli中所有表 所有权限
grant ALL on db_xiaoli.* to zs@'%';

撒销权限(Revoke)

#语法: 
revoke privileges(操作) on databasename(表名字).tablename(表里面的字段) from username(用户)@'host;


#啥也不能回收,不会对GRANTALL PRIVILEGES ONdb xiaoli*TO zs @%有
revoke DELETE on db_xiaolit.t p1 user from zs@'%';#可以回收GRANT SELECT,UPDATE ON 'db xiaoli'.'t_p1'user TO 'zs'@'%'
revoke all on db _xiaoli.t_p1_user from zs@%';#可以回收
GRANT ALL PRIVILEGES ON db_xiaoli. TO zs @'%';revoke all on db_xiaolit.* from zs@'%';

#注: revoke只能回收grants列表中更小的
 

查看用户权限

命令: show grants for 用户名;

show grants fro 'zs'@'%';

注:默认权限(游客权限)GRANT USAGE ON *.* TO 'zs'@'%'

7.5与8.0版本不同


5.7版本

①创建用户并设置登录密码

#命令: create user 用户名 identified by'密码';

注: identified by会将纯文本密码加密作为散列值存储

create user ls identified by '123456';

②修改用户密码

命令: set password for 用户名=password('新客码');

set password for zs=password(123456);

刷新:flush privileges;


8.0版本

①创建用户并设置登录密码
用户名密码创建需要分开

命令: create user 用户名

create user ls;

②修改用户密码

ALTER USER 用户 IDENTIFIED  WITH mysql_native_password by '1234';

ALTER USER 'Is'@'%' IDENTIFIED WITH mysql_native_password By '1111';
flush privileges; 

五、思维导图总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/593001.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ArkTS语言应用开发入门指南与简单案例解析

文章目录 前言创建项目及其介绍简单案例学习本文总结问答回顾-学习前言 在前几节课中,我们已经了解了ArkTS语言的特点以及其基本语法。现在,我们将正式利用ArkTS来进行应用开发。本节课将通过一个快速入门案例,让大家熟悉开发工具的用法,并介绍UI的基础概念。 创建项目及…

Mnist手写体数字数据集介绍与在Pytorch中使用

1.介绍 MNIST(Modified National Institute of Standards and Technology)数据集是一个广泛用于机器学习和计算机视觉研究的常用数据集之一。它由手写数字图像组成,包括0到9的数字,每张图像都是28x28像素的灰度图像,图…

探索大模型语言(LLM)科技的革新

文章目录 一. 引言二. 了解大模型语言2.1 什么是LLM?2.2 大模型与大模型语言的区分 三. 机器学习3.1 AI开发3.2 机器学习服务 四. 大模型的应用场景五. 全篇总结 一. 引言 自然语言处理领域的发展取得了巨大的突破,其中广义语言模型(LLM&…

pytorch学习笔记

torchvision处理图像的 pytorch官网上看数据集的包,COCO数据集目标检测、语义分割,cifar物体识别 预训练好的模型 这个模块是图片的处理 root-位置,train-创建的true是个训练集,transform 前面是输出图片的数据类型,“…

ByteTrack算法流程的简单示例

ByteTrack ByteTrack算法是将t帧检测出来的检测框集合 D t {\mathcal{D}_{t}} Dt​ 和t-1帧预测轨迹集合 T ~ t − 1 {\tilde{T}_{t-1}} T~t−1​ 进行匹配关联得到t帧的轨迹集合 T t {T_{t}} Tt​。 首先使用检测器检测t帧的图像得到检测框集合 D t {\mathcal{D}_{t}} …

md文件图片上传方案:Github+PicGo 搭建图床

文章目录 1. PicGo 下载2. 配置Github3. 配置PicGo4. PicGo集成Typora4.1 picGo监听端口设置 5. 测试 1. PicGo 下载 下载地址:https://molunerfinn.com/PicGo/ 尽量下载稳定版本 2. 配置Github 1. 创建一个新仓库,用于存放图片 2. 生成一个token&a…

【安卓的签名和权限】

Android 编译使用哪个key签名? 一看Android.mk 在我们内置某个apk的时候都会带有Android.mk,这里面就写明了该APK使用的是什么签名,如: LOCAL_CERTIFICATE : platform表明使用的是platform签名 LOCAL_CERTIFICATE : PRESIGNED…

SpringBoot整合ElasticSearch实现CRUD操作

本文来说下SpringBoot整合ES实现CRUD操作 文章目录 概述项目搭建ES简单的crud操作保存数据修改数据查看数据删除数据 本文小结 概述 SpringBoot支持两种技术和es交互。一种的jest,还有一种就是SpringData-ElasticSearch。根据引入的依赖不同而选择不同的技术。反正作…

代码随想录算法训练营Day16 | 654.最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树

LeetCode 654 最大二叉树 本题思路:我们可以看到每次其实这个找最大值,然后创建节点的过程就是一个二叉树的前序遍历的过程。所以,我们可以递归来完成它。 先创找到数组中,最大的值的下标,然后创建根节点然后根据下标…

c语言-整型在内存的存储

文章目录 前言一、整型数值在内存中的存储1.1 整型数值的表示形式1.2 二进制的表示形式1.3 整数在内存中存储 二、大端字节序存储和小端字节序存储2.1 大端字节序存储2.2 小端字节序存储2.3 练习 总结 前言 本篇文章叙述c语言中整型数据在内存中的存储方式。 一、整型数值在内…

Vue学习计划-Vue3--核心语法(一)OptionsAPI、CompositionAPI与setup

1. OptionsAPI与CompositionAPI Vue2的API设计是Options(配置)风格的Vue3的API设计是Composition(组合)风格的 Options API的弊端: Options类型的API,数据、方法、计算属性等,是分散在:data、methods、computed中的,若…

【操作系统xv6】学习记录2 -RISC-V Architecture

说明:看完这节,不会让你称为汇编程序员,知识操作系统的前置。 ref:https://binhack.readthedocs.io/zh/latest/assembly/mips.html https://www.bilibili.com/video/BV1w94y1a7i8/?p7 MIPS MIPS的意思是 “无内部互锁流水级的微…

Maple 2021安装包下载及安装教程

Maple 2021下载链接:https://docs.qq.com/doc/DUk9MQ1BPRHRYWU9s 1.鼠标右键解压到“Maple 2021” 2.选中Setup,鼠标右击选择“以管理员身份运行” 3.点击“Next” 4.选择I accept the agreement,点击“Next” 5.选择软件安装路径&#xff0c…

IDEA JAVA Spring Boot运行Hello World(1.8)

参考资料: Spring Boot运行Hello World - 知乎https://blog.csdn.net/weixin_44005516/article/details/108293228(解决bug)SpringBoot入门第一章:Hello World-java教程-PHP中文网 (仅参考如何运行程序)java 8安装教程 java 8安装教程_java8安装-CSDN博…

力扣:763. 划分字母区间(贪心,哈希)

题目: 给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。 注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍然是 s 。 返回一个表示每个字符串片段的长度…

SpringBoot集成MQTT协议

简介 MQTT 可以被解释为一种低开销,低带宽占用的即时通讯协议,可以用较少的代码和带宽为远程设备连接提供实时可靠的消息服务,它适用于硬件性能低下的远程设备以及网络状况糟糕的环境下,因此 MQTT 协议在 IoT(Interne…

1月3日代码随想录反转二叉树

226翻转二叉树 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1]示例 2: 输入:root [2,1,3] 输出:[2,3,…

原生JS做别踩白块游戏

思路 创建初始一个按钮并为他添加点击监听开始创建随机方块,并样式_box.offsetTop speed px结合setInterval使得方块不断下移创建和删除方块的原则:box.offsetTop>0(可视区上部没有方块了)时候需要创建一行方块,…

江西速欣商务咨询有限公司:深度解析停息挂账,助您财务重启

停息挂账问题可能对个人或企业财务产生严重影响,但江西速欣商务咨询有限公司以其深度解析停息挂账的专业能力,致力于助您重新启动财务,实现财务的良性发展。 专业团队,深度解析挂账难题 速欣商务咨询拥有一支专业团队&#xff0c…

域名授权验证系统PHP源码,盗版追踪、双重授权和在线加密功能,附带安装教程

源码介绍 PHP域名授权验证系统是一个功能强大的系统,提供了多项功能来保护你的域名和软件的合法性。它包括盗版追踪、域名IP双重授权、在线加密等功能,同时还提供了PHP授权验证更新系统的完整版,方便你进行一键更新和生成自助授权。 盗版追…