MySQL四大引擎建库建表账号管理

目录

一. 数据库四大引擎

1.1 引擎查看

1.2 InnoDB引擎

1.3 MyISAM引擎

1.4 MEMORY引擎 

1.5 Archive引擎

二. 数据库管理

2.1 元数据库

2.2 数据库的增删改查及使用

2.3 权限相关表

 三. 数据表管理

3.1 三大范式

3.2 基本数据类型

优化原则

分类

四. 数据库账号管理

4.1 通用

4.2 不同

4.2.1 MySQL5.7版本

4.2.2 MySQL8.0版本

思维导图


一. 数据库四大引擎

1.1 引擎查看

查看命令

  • SHOW ENGINES

Support字段说明

  • default为默认引擎
  • YES表示可以使用
  • NO表示不能使用

1.2 InnoDB引擎

使用场景

  • 事务性的一般使用该引擎,用途最广,如果不知道使用哪种引擎,就使用该引擎

特点

  • 修改快,支持事务(只有它支持事务)——行锁
  • 存储限制:64TG

1.3 MyISAM引擎

使用场景

  • 在开发中,数据字典、系统参数表会用到。
  • 大量查询,很少修改的时候

特点

  • 强调了快速读取操作——表锁
  • 存储限制:256TG
  • 不支持事务

1.4 MEMORY引擎 

使用场景

  • 由于易失性,用于存储在分析中产生的中间表

特点

  • 所有的数据都存储在内存中,一旦服务器重启,所有的表数据都会丢失但表结构会保存
  • 存储限制:取决于RAM(随机存储器)
  • 不支持事务

1.5 Archive引擎

使用场景

  • 在日志和数据采集时使用

特点

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

二. 数据库管理

2.1 元数据库

简介

  • 记录MySQL自身数据的数据库

元数据库分类

1、information_schema

信息数据库,保存MySQL所维护的其他数据库信息。

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

2、mysql

核心数据库,主要负责存储数据库的用户,权限设置,关键字等。

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

3、performance_schema

用于mysql的监控数据的存放。

2.2 数据库的增删改查及使用

  1. 使用:use 数据库名
  2. 增加:create database if not exists 数据库名 default charset utf8 collate utf8_general_ci;(设置字符集编码以及不区分大小写)
  3. 查询所有数据库:show database
  4. 删除:drop database 数据库名;

2.3 权限相关表

1、user表(用户层权限)

决定用户拥有哪些数据库的权限

2、db表(数据库层权限)

决定用户对于该数据库哪些表具有操作权限

3、tables_priv表(表层权限)

决定了用户对于具体某张表具有增删改查的权限

4、columns_priv表(字段层权限)

决定了用户对于某张表的哪些字段具有操作权限

 三. 数据表管理

3.1 三大范式

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

假如说,将一个地址湖南省长沙市岳麓区浪琴湾15栋。这个时候需要用四个字段来保存这个地址:province保存省份、city保存市、area保存区域、address保存详细地址。这样就符合了第一范式。

  • 第二范式:主键约束

 也就是说一张表的每一个字段它都要依托于主键存在。例如:订单项表里有编号、单价、数量、小计。这里的小计是依托于单价和数量存在,这就违背了第二范式。

  • 第三范式:外键约束

假如说在医疗系统中,需要拿到一个患者的档案信息,那么就需要用到两张表,患者信息表和医生信息表。要在患者信息表中保存医生id,而不能直接在患者表中拿到医生姓名。

3.2 基本数据类型

优化原则

1、越小越好

  • 越小越快;
  • 拥有更小的磁盘空间、内存、CPU缓存;
  • 更少的CPU周期。

2、简单就好

  • 整型比字符串操作代价更小;
  • 用时间类型表示日期,而不是字符串。

3、尽量避免使用NULL

  • 尽量指定列为NOT NULL,特别是需要建索引的列;
  • 查询含有NULL的类,MySQL更难优化(不利于使用索引、索引统计更复杂、值比较 更复杂);
  • 用整型值而非字符串表示IP地址。

分类

1、整数

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

2、实数(带有小数点)

  • float 4个字节
  • double 8个字节
  • decimal 最多允许65个数字(涉及到数字的运算最好使用decimal)

3、字符串

  • char:定长,MySQL根据定义字符串的长度一次分配足够的空间;

适用场景:较短的字符串,且所有值接近同一长度。

  • varchar:比定长类型节约空间;

适用场景:字符串的最长长度比评估长度大很多,列的更新较少;

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

4、text存储字符数据 & blob存储二进制数据

  • tinytext                                                 tinyblob
  • smalltext                                              smallblob
  • mediumtext                                          mediumblob
  • text                                                       blob
  • longtext                                                longblob

都为存放很大的数据而设计;

与其他数据不同,都作为独立的对象存储;

当值太大时,使用外部存储区存储。

5、日期时间

  • datetime

精度:秒;

与时区无关,8个字节存储空间;

范围:1001至9999年。

  • timestamp

保存1970年1月1日午夜以来的秒数;

占用4个字节存储空间;

范围:1970年至2038年;

与时区有关;

默认为NOT NULL;

通常尽量使用timestamp。

  • date:yyyy-MM-dd
  • time:HH:mm:ss

6、选择标识符

  • 用来进行关联操作;
  • 在其他表中作为外键;
  • 整型通常是标识符的最好选择;
  • 相关的表中使用相同的数据类型;
  • 尽量避免字符串作为标识列,尤其是随机生成的字符串(如uuid)

原因:①插入值被随机写到索引的不同位置,insert慢,容易导致页分裂,磁盘随机读取;

②逻辑上相邻的行被分布在磁盘和内存的不同地方,select慢;

③使MySQL查询缓存失效;

④如果需要存储uuid,则应将“-”去除

四. 数据库账号管理

4.1 通用

1、查询用户

select *from user;

2、查看用户常用信息

select host,user from user;

user表中host列的值的意义:

  • %                匹配所有主机
  • localhost     localhost不会被解析成IP地址,直接通过UNIXsocket连接
  • 127.0.0.1    会通过TCP/IP协议连接,并且只能在本机访问

3、删除用户

drop user 用户名;

4、权限操作

  1. 设置权限(grant):grant privileges on databasename.tablename to username@'host';  
  2. 撤销权限(revoke):revoke privileges on databasename.tablename from username@'host';        revoke只能回收grants列表中更小的权限;
  3. 查看用户权限:show grants for 用户名;

4.2 不同

4.2.1 MySQL5.7版本

1、创建用户并设置登录密码

create user 用户名 identified by '密码';

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

2、修改用户密码

set password for 用户名 = password('新密码');

flush privileges;

4.2.2 MySQL8.0版本

1、创建用户并设置登录密码

用户名密码创建需要分开;

create user 用户名;

2、修改用户密码

alert user 用户 identified with mysql_native_password by'123456';

思维导图

 

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

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

相关文章

Service Weaver:Google开源基于分布式应用程序开发的框架,重新定义微服务边界

大家好,我是萧楚河,公众号:golang面试经典讲解,感谢关注,一起学习一起成长。一、前言 今年6月,一群谷歌员工(由谷歌软件工程师Michael Whittaker领导)发表了一篇名为“Towards Mode…

wsl(ubuntu)创建用户

我们打卡ubuntu窗口,如果没有创建用户,那么默认是root用户 用户的增删改查 查 查询所有的用户列表 cat /etc/passwd | cut -d: -f1cat /etc/passwd: 这个命令用于显示 /etc/passwd 文件的内容。/etc/passwd 文件包含了系统上所有用户的基本信息。每一…

SpringBoot 中实现订单30分钟自动取消的策略

简介 在电商和其他涉及到在线支付的应用中,通常需要实现一个功能:如果用户在生成订单后的一定时间内未完成支付,系统将自动取消该订单。 本文将详细介绍基于Spring Boot框架实现订单30分钟内未支付自动取消的几种方案,并提供实例…

Odoo | Module | 统计系统周期使用人数/当前在线人数

文内材料 GITHUB地址 前言介绍 Odoo作为开源ERP系统的No.01,近年愈发的得到国内很多公司的关注。 虽然它的定位是中小型企业的ERP管理系统,但是在几年的Odoo开发实施过程中,有不足50人的小型企业,也有上万人的中大型企业。功能快速落地和…

ipyvizzu:一款可以绘制超级惊艳的可视化动图的 Python 工具包

今天我给大家介绍一款可视化模块,使用它可以绘制出十分惊艳的动图效果,那么当然第一步我们首先是要安装一下该模块,通过pip命令行来安装 pip install ipyvizzu牛刀小试 我们首先来简单地使用该模块来绘制一张动图,用Pandas导入数…

2024年阿里云服务器优惠活动大全,实时更新

阿里云服务器优惠活动大全包括:云服务器新人特惠、云小站、阿里云免费中心、学生主机优惠、云服务器精选特惠、阿里云领券中心等,活动上阿里云服务器ECS经济型e实例2核2G、3M固定带宽99元一年、轻量应用服务器2核2G3M带宽轻量服务器一年61元,…

【大数据进阶第三阶段之Hive学习笔记】Hive安装

目录 1、环境准备 2、下载安装 3、配置环境变量 4、配置文件 4.1、配置hive-env.sh ​编辑4.2、配置hive-site.xml 5、上传配置jar 6、启动 1、环境准备 安装hadoop 以及 zookeeper、mysql 【大数据进阶第二阶段之Hadoop学习笔记】Hadoop 运行环境搭建-CSDN博客 《z…

二刷Laravel 教程(用户模型)总结Ⅲ

一、数据库迁移 当我们运行迁移时,up 方法会被调用;(创建表) 当我们回滚迁移时,down 方法会被调用。(删除表) public function up() { //create 方法会接收两个参数:一个是数据…

C++string类的介绍及常用函数用法总结

🎉个人名片: 🐼作者简介:一名乐于分享在学习道路上收获的大二在校生🐻‍❄个人主页🎉:GOTXX 🐼个人WeChat:ILXOXVJE🐼本文由GOTXX原创,首发CSDN&a…

更改ERPNEXT源

更改ERPNEXT源 一, 更改源 针对已经安装了erpnext的,需要更改源的情况: 1, 更改为官方默认源, 进入frapp-bench的目录, 然后执行: bench remote-reset-url frappe //重设frappe的源为官方github地址。 bench remote-reset-url…

如何配置 VS Code 实现 git 密码免输入

目录 问题描述尝试过的失败方法问题分析最终采用的解决方案:利用 ssh key 提供密码免输入功能安装 git windows 命令工具在windows本地生成 ssh key将公钥安装到 git 服务器第一种方法第二种方法调试方法 参考资料: 问题描述 在 Windows 上,使用 Visual…

AI股票崩盘预测模型(企业建模_论文科研)ML model for stock crash prediction

对齐颗粒度,打通股票崩盘底层逻辑,形成一套组合拳,形成信用评级机制良性生态圈,重振股市信心!--中国股市新展望!By Toby!2024.1.3 综合介绍 股票崩盘,是指证券市场上由于某种原因&a…

玩机技巧|拿到新电脑or电脑重装系统后该如何设置

1、关闭权限申请 你是否碰到过,在打开一个应用时,电脑总会询问”你要允许此应用对你的设备进行更改吗?",这个或许很烦,下面我们就讲这个关闭,告别不断地请求。(此处你点击是,便…

ssm基于JSP的明水县苹果网吧计费管理系统的设计与实现论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本明水县苹果网吧计费管理系统就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大…

包含所有字符的最短字符串

由题还是很容易想到可以用一个哈希表来统计字符串中每个字符出现的次数。首先扫描字符串t,每扫到一个,哈希表中对应值加1。然后扫描字符串s,每扫描一个就检查哈希表中是否包含该字符,没有则忽略不计。如果存在,对应的值…

【数据结构】八大排序之快速排序算法

🦄个人主页:修修修也 🎏所属专栏:数据结构 ⚙️操作环境:Visual Studio 2022 目录 一.快速排序简介及思路 二.快速排序代码实现的三种方式 📌左右交换法 📌挖坑填坑法 📌前后指针法 三.快速排序的时间复杂度分析…

ssm基于HTML5的交流论坛的设计与实现+vue论文

摘 要 信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古…

【Java EE初阶九】多线程进阶一(锁策略)

前言 锁的策略:加锁过程中,即处理冲突的过程中,需要涉及到的一些不同的处理方式(此处锁策略并不是java独有的),本篇内容主要是讲解一下关于锁的相关知识点; 1. 关于锁的分组 1.1 第一组&#x…

动态内存管理:malloc free

//——————1.动态内存管理(内存空间) 共四个函数:malloc free calloc realloc 1. 为什么存在动态内存分配 我们已经掌握的内存开辟方式有: int val 20;//在栈空间上开辟四个字节 char arr[10] { 0 };//在栈空间上开…

一、Qt介绍

一、Qt介绍 1、介绍 Qt是一套程序开发库,但是与MFC(依赖于Windows API)不同,Qt是跨平台开发库。 Qt获取:[Qt下载地址](https://download.qt.io/archive/qt/)2、Qt安装 QtMinGWSourcesQt ChartsQt Data Visualizatio…