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

目录

一. 数据库存储引擎

        1.1 存储引擎查看

        1.2 InnoDB

        1.3 MyISAM

        1.4 MEMORY

        1.5 ARCHIVE

二. 数据库管理

        2.1 元数据库简介

        2.2 元数据库分类

        2.3 数据库的增删改查及使用:

        2.4 MySQL库的权限

三. 数据表管理

        3.1 三大范式

        3.2 基本数据类型

        3.2.1 优化原则

        3.2.2 值类型分类

        3.2.3 text&blob

        3.2.4 日期时间

        3.2 5 选择标识符

四. 数据库账号管理

        4.1 相同

        4.2 不同

        4.2.1 MySQL 5.7版本

        4.2.2 MySQL 8.0版本

五. 思维导图


一. 数据库存储引擎

        1.1 存储引擎查看

命令:SHOW ENGINES

support字段说明:

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

        1.2 InnoDB

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

特点:

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

        1.3 MyISAM

使用场景:大量查询,很少修改的场景。例如:数据字典,系统参数

特点:

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

        1.4 MEMORY

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

特点:

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

        1.5 ARCHIVE

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

特点:

  • 只允许插入和查询,不允许修改和删除,压缩存储,节约空间,可以实现高并发的插入,支持在自增ID上建立索引
  • archive表比MyISAM表要小大约75%,比支持事务处理的InnoDB表小大约83%
  • 不支持索引(自增ID列除外)

二. 数据库管理

        2.1 元数据库简介

MySQL自身数据的数据库,就是数据库安装成功后,默认带的,就叫元数据库。

        2.2 元数据库分类

  • information_schema:信息数据库,保存mysql所维护的其他数据库信息。例如:数据库名,数据库的表,表栏的数据类型与访问权限等
  • mysql:核心数据库,主要负责存储数据库的用户、权限设置、关键字等。mysql自己需要使用的控制和管理信息。
  • performance_schema:用于mysql的监控数据的存放。
  • sys:Sys库所有的数据源来自:performance_schema。目标是把performance_schema 的把复杂度降低,让 DBA 能更好的阅读这个库里的内容。让DBA更快的了解 DB 的运行情况。

        2.3 数据库的增删改查及使用:

  • 使用数据库:use 数据库名
  • 创建数据库:create database if not exists 数据库名 default charset utf8 collate utf8_general_ci;(设置了字符集编码以及不区分大小写)
  • 显示所有的数据库:show databases;
  • 删除数据库:drop database 数据库名;

        2.4 MySQL库的权限

  • user表(用户表权限):用户有哪些数据库的操作权限
  • db表(数据库层权限):用户对这个数据库的哪些表有操作权限
  • tables_priv表(表层权限):用户对于表有哪些操作权限:增加、删除、修改、查询、创表、删除表
  • columns_priv表(字段层权限):决定了用户针对于某一张表的哪些字段有操作权限

三. 数据表管理

        3.1 三大范式

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

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

第二范式:主键约束

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

第三范式:外键约束

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

        3.2 基本数据类型

        3.2.1 优化原则

1. 更小通常更好:

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

2. 简单就好:

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

3. 尽量避免NULL:

  • NULL为列的默认值,但除非确实需要,应尽量避免使用NULL
  • 尽量指定列为NOT NULL,特别是需要建索引的列
  • 查询中包括有NULL的类,MySQL更难优化 不利于使用索引  索引统计更复杂  值比较 更复杂
  • 用整形值而不是字符串表示IP地址: INET_ATON() ② INET_NTOA()
        3.2.2 值类型分类

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: 比定长类型节约空间

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

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

        3.2.3 text&blob

1. 都为存放很大的数据而设计
2. 与其他数据不同,都作为独立的对象存储
3. 当值太大时,使用外部存储区存储

1. text存储字符数据:

  • tinytext
  • smalltext
  • mediumtext
  • text
  • longtext

2. blob存储二进制数据

  • tinyblob      
  • smallblob
  • mediumblob
  • blob
  • longblob
        3.2.4 日期时间

1. datetime:

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

2. timestamp:

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

3. date:yyyy-MM-dd

4. time:HH:mm:ss

        3.2 5 选择标识符
  • 用来进行关联操作
  • 在其他表中作为外键
  • 整形通常是标识列的最后选择
  • 相关的表中使用相同的数据类型
  • 尽量避免字符串作为标识列,尤其是随机生成的字符串,(如:UUID)导致insert与select都很慢

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

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

        3. 使MySQL查询缓存失效

        4. 如果需要存储UUID,则应将“-”去除

四. 数据库账号管理

        4.1 相同

查询用户:SELECT * from user;

查看用户常用信息:select host,user from user;

删除用户(慎用):#命令:drop user 用户名;

                                #drop user ls;

权限操作:

        ① 设置权限(Grant)

        #语法:grant privileges on databasename.tablename to username@'host';
        #给zs用户 赋予 数据库db_xiaoli中的表t_p1_user 查询权限
         grant SELECT on db_xiaoli.t_p1_user to zs@'%';

         #给zs用户 赋予 数据库db_xiaoli中的表t_p1_user 修改权限
        grant UPDATE on db_xiaoli.t_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';
        #啥也不能回收,不会对GRANT ALL PRIVILEGES ON `db_xiaoli`.* TO `zs`@`%`有任何影响
        revoke DELETE on db_xiaoli.t_p1_user from zs@'%';

        #可以回收GRANT SELECT, UPDATE ON `db_xiaoli`.`t_p1_use` TO `zs`@`%`这条赋权语句带来的权限
        revoke all on db_xiaoli.t_p1_use from zs@'%';

        #可以回收GRANT SELECT, UPDATE ON `db_xiaoli`.* TO `zs`@`%`这条赋权语句带来的权限
        revoke all on db_xiaoli.* from zs@'%';


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

        ③ 查看用户权限

        #命令:show grants for 用户名;
        show frants for 'zs'@'%';

        4.2 不同

        4.2.1 MySQL 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;

        4.2.2 MySQL 8.0版本
  • 创建用户并设置登录密码:

        #用户名密码创建需要分开
        #命令:create user 用户名;
        create user ls;

  • 修改用户密码:

        #ALTER USER 用户 IDENTIFIED WITH mysql_native_password BY '新密码';
        ALTER USER 'ls'@'%' IDENTIFIED WITH mysql_native_password BY '新密码';
        flush privileges;

五. 思维导图

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

将DOM结构转换成图片保存至本地或保存至剪切板

在新业务需求中,碰到这样一个场景,需要将后端返回的表格数据,保存至本地或者保存至剪切板,直接发送给用户使用。 1. 将内容转换成图片并保存至本地 1.1 交互效果 如图所示,想要点击复制按钮后,将下面这个…

echarts点击柱子、线节点、横坐标标签

echarts点击柱子、线节点、横坐标标签 x轴标签要为标签文字添加点击事件,必须先在xAxis里设置响应事件 xAxis: {triggerEvent: true, },然后直接监听 thisChart.on("click" ,function (params) {console.log(params) });通过params.componentSubType来…

JNPF低代码体验情况

目录 可视化拖拽搭建 平台功能特征 01、高性能、高拓展 02、满足通用场景 03、私有化部署 04、多种数据库 05、项目部署简单 06、平台全源码合作 最后 分享下引迈信息的 JNPF 吧,面向研发人员开发使用、100%源码、前后端分离的低代码: JNPF主打…

鸿鹄电子招投标系统:源码级别解析电子招投标的精髓

招投标管理系统是一个集门户管理、立项管理、采购项目管理、采购公告管理、考核管理、报表管理、评审管理、企业管理、采购管理和系统管理于一体的综合性应用平台。它适用于招标代理、政府采购、企业采购和工程交易等业务的企业,旨在提高项目管理的效率和质量。该系…

芯课堂 | MCU之EXT

概述 本文将介绍一下华芯微特MCU的嵌套向量中断控制器(NVIC)与外部中断/事件控制器(EXTI)的使用方法等。 01.嵌套向量中断控制器(NVIC) NVIC的全称是Nested vectoredinterrupt controller,即嵌…

Navicat Premium各版本安装指南

Navicat Premium下载链接 https://pan.baidu.com/s/1rHvboQJ7ec4f8MUi-6kZww?pwd0531 1.鼠标右击【Navicat Premium 16(64bit)】压缩包(win11及以上系统需先选择“显示更多选项”)选择【解压到 Navicat Premium 16(64bit)】。 2.打开解压后的文件夹&a…

AI写作生成器,这4款你要试试

随着人工智能技术的不断发展,AI写作生成器逐渐成为了学术界和商业领域的热门工具。它们能够帮助用户快速生成高质量的论文、文章和其他文本内容。在众多的AI写作生成器中,有一些不常见但却非常优秀的中文软件,今天我们就来推荐这4款你一定要试…

深度学习:大规模模型分布式训练框架DeepSpeed

深度学习:大规模模型分布式训练框架DeepSpeed DeepSpeed简介DeepSpeed核心特点DeepSpeed如何工作?DeepSpeed如何使用?参考文献 DeepSpeed简介 随着机器学习模型变得越来越复杂和庞大,训练这些模型所需的计算资源也在不断增加。特别…

satellite-image-deep-learning,一个遥感深度学习方向的宝藏网站

今天我们分享一个深度学习遥感相关的网站:「satellite-image-deep-learning」。这是一个github库,里面含有大量应用于卫星和航空图像的深度学习资源。 主要包括以下几个方面: annotation:提供数据集注释信息,里面包含…

【数据湖架构】数据湖101:概述

数据湖是非结构化和结构化数据池,按原样存储,没有特定的目的,可以建立在多种技术上,如Hadoop,NoSQL,Amazon Simple Storage Service,关系数据库或各种组合根据一份名为“什么是数据湖”的白皮书…

Mysql8.0新特性

一,redo log重构 (涉及写入缓存的点:redo log 8.0之前通过两个锁及队列的方式保证数据的一致性,8.0之后,去掉锁,采用了区间的方式,区间内的所有日志是原子性的,都是串行化执行&…

神经网络:激活函数的介绍

神经网络的激活函数是一种非线性函数,它被应用于每个神经元的输出,以引入非线性性质到网络中。 激活函数的目的是将输入转换为输出,并且将输出限制在特定的范围内。它们非常重要,因为线性变换(例如加法和乘法&#xf…

听GPT 讲Rust源代码--compiler(4)

File: rust/compiler/rustc_codegen_gcc/src/back/mod.rs rust/compiler/rustc_codegen_gcc/src/back/mod.rs 文件是 Rust 编译器的源代码中的一个模块,主要负责与 GCC(GNU 编译器集合)相关的后端代码生成。 在 Rust 编译器的架构中&#xff…

从“五力”看百亿西凤的必然性

执笔 | 文 清 编辑 | 萧 萧 2023年末,西凤成功突破市场阻碍、跑赢行业周期,正式跻身中国百亿白酒品牌阵容。这是一份全行业及全体西凤人“预期之内”的成绩单。 当下,中国白酒已经进入“存量竞争”时代,马太效应使得强者恒强…

Minitab 各版本安装指南

Minitab下载链接 https://pan.baidu.com/s/1PLqocknkoRGGI9lbV3e45A?pwd0531 1.鼠标右击【Minitab 21(64bit)】压缩包(win11及以上系统需先点击“显示更多选项”)选择【解压到 Minitab 21(64bit)】。 2.打开解压后的文件夹,鼠标右击【setu…

集群容器频繁OOMKilled的排查经历

背景 我司采用的是k8s治理编排容器服务 出现的问题:线上某个应用pod频繁重启,13天内每个pod重启约8~9次 排查步骤 1.查看pod重启原因和重启时间点 kubectl describe pods okr-indicator-deploy-84bc5779c-55xsn -n rishiqing-v2 State: …

【Proteus仿真】【51单片机】超声波测距系统

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真51单片机控制器,使用动态数码管、按键、HCSR04超声波、蜂鸣器模块等。 主要功能: 系统运行后,数码管显示超声波检测距离,当检测距离…

报告解读:中国新一代终端安全市场洞察,2023

报告解读 中国新一代终端安全市场洞察 2023 安全防御的“最前线” 01 混沌的企业安全 以下来自CSO们最关注的安全热点问题: Q1我们如何看待当下泛化的终端安全,混合的IT环境企业面临的安全变化? IDC:伴随着全球数字化转型的快…

【番外】【Airsim in Windows ROS in WSL2-Ubuntu20.04】环境配置大全

【番外】【Airsim in Windows &ROS in WSL2-Ubuntu20.04】环境配置大全 【前言(可省略不看)】1.在windows上面部署好UE4AirSim联合仿真环境2.在windows上面部署wsl2系统以及在wsl2上面部署ubuntu系统3.安装好ubuntu系统之后,目前只能在命…

Multipath多路径管理基础介绍与安装配置使用

0x00 前言简述 Q:什么是Multipath多路径? 答:Multipath I/O 电脑储存技术,指利用两个以上的路径同时在CPU与储存设备之间传送讯号,以达到侦错与强化效能的目的。 简单的说当服务器到某一存储设备有多条路径时,每条路径都会识别为一个单独的…
最新文章