第六周作业

1. 总结关系型数据库相关概念,关系,行,列,主键,惟一键,域。

关系Relational:是一张二维表,其中表的行和列的次序并不重要
行row:表中的每一行,称为一条记录record
列column:表中的每一列,称为字段field
主键Primary key:PK,用于唯一确定一个记录的字段,一张表只能有一个主键,且主键字段不能为null
外键Foreign key:处理一对多表的关系
唯一键Unique key:用于唯一确定一个记录的字段,一张表可以有多个唯一键,唯一键的字段可以为null
域domian:属性的取值范围

2. 总结关联类型,1对1,1对多,多对多关系。可以自行设计表进行解释。

一对一联系:在表A中创建一个字段,存储另一个表的主键值。例如人和身份证号的关系。一一对应
一对多联系:外键。例如班级与学生的关系。一个班级对应多个学生
多对多联系:增加第三张表。例如学生和所选的课程。一个学生选多个课程或者多个学生共同选了一门课程

3. 总结mysql设计范式

主要以第一范式,第二范式,第三范式为主。在合适的场景下违反范式
第一范式:无重复的列,每一列都是不可分割的基本数据项,同一列中不能有多个值。
第二范式:第二范式必须先满足第一范式,属性完全依赖于主键,要求表中的每个行必须可以被唯一地区分。
第三范式:满足第三范式必须先满足第二范式属性,非主键属性不依赖于其它非主键属性。

4. 总结Mysql多种安装方式,及安全加固,并总结mysql配置文件。

MySQL的安装方式有:yum安装,二进制包安装,源码编译安装,基于docker容器创建数据库。
安全加固:针对MySQL5.6之前的版本可以运行mysql_secure_installation脚本,做设置数据库管理员root口令,禁止root远程登录。删除anonymous用户账号,删除test数据库,防止SQL的注入攻击
MySQL配置文件:常位于/etc/my.cnf  [mysqld]下定义服务器端配置,[mysql]定义客户端配置,监听tcp端口默认3306

1. 完成将server和client端的mysql配置默认字符集为utf8mb4;

vim /etc/my.cnf|
[mysqld]
character-set-server=utf8mb4

[client]
default-character-set=utf8mb4

systemctl restart mysqld

5. 掌握如何获取SQL命令的帮助,基于帮助完成添加testdb库,字符集utf8, 排序集合utf8_bin.创建host表,字段(id,host,ip,cname等)

登录到MySQL后可以使用\h或者help命令来显示帮助列表。help xxx接具体MySQL命令,可以查看服务端的命令具体信息。

create database testdb;
create table host;

6. 根据表扩展出几个语句,完成总结DDL, DML的用法,并配上示例。

DDL语句:创建:CREATE DATABASE db_name;    CREATE TABLE tbl_name;
                  修改:ALTER DATABASE db_name CHATACTER SET utf8;
                  删除:DROP DATABASE db_name;    DROP TABLE tbl_name;
                  查看所有数据库名:SHOW DATABASES;
                  查看库里所有表名:SHOW TABLES;
                  查看表结构:DESC tbl_name;
DML语句:插入记录:INSERT tbl_name VALUES(xxx,xxx,xxx
                  修改记录:UPDATE tbl_name SET age=18 WHERE id=2 #用WHERE指定修改哪一条记录
                  UPDATE tbl_name SET age=18; #此操作非常危险,表内的每条记录都会被修改!
                  删除记录:DELETE FROM tbl_name WHERE id=2;#要指定要删除哪一条记录
                  DELETE FROM tbl_name;  #此操作非常危险,会清空表内所有记录数据,且不会删除表!

7. 总结mysql架构原理

MySQL是C/S架构的

1、连接器:管理连接、授权认证。

2、查询缓存:存储SELECT语句及其结果,如果缓存命中,结果会直接返回。

3、分析器:词法分析、语法分析。

4、优化器:生成执行计划。

5、 执行器:执行查询,调用存储引擎API。

8. 总结myisam和Innodb存储引擎的区别。

myisam:不支持事务,使用表级锁,不支持聚簇索引,不支持MVCC高并发,读写互相阻塞
Innodb:支持事务,使用行级锁,支持聚簇索引,支持MVCC高并发,读写阻塞与事务隔离

9. 总结mysql索引作用,同时总结哪些查询不会使用到索引。

MySQL索引作用:降低服务需要扫描的数据量,减少I/O次数,加快数据库数据查询。
                              帮助服务器避免排序和使用临时表
                              将随机I/O转为顺序I/O

查询条件左模糊时不会使用索引

10. 总结事务ACID事务特性

A:atomicity 原子性;整个事务中的所有操作要么全部成功执行,要么全部失败后回滚
C:consistency 一致性;数据库总是从一个一致性状态转换成另一个一致性状态
I:Isolation 隔离性;一个事务所做出的操作在提交之前,是不能为其他事务所见
D:durability 持久性;一旦事务提交,其所做的修改会永久保存与数据库中

11. 总结事务日志工作原理。

事务日志:有两块记录日志文件redo log和undo log ;
redo log:记录某数据块被修改后的值,数据更新前先记录redo log,用来恢复未写入data file的已成功事务更新的数据。
undo log:保存与执行的操作相反的操作,即记录某数据被修改前的值,用来在事务失败时进行rollback。

12. 总结mysql日志类型,并说明如何启动日志。

MySQL的日志类型有:
事务日志:transaction log
错误日志:error log
通用日志:general log
慢查询日志:slow query log
二进制日志:binary log
中继日志:relay log

启动二进制日志
修改配置文件/etc/my.cnf文件添加
[mysqld]
log_bin= /var/log/mysql/mysql-bin.log
server-id=1

systemctl restart mysqld #重启MySQL服务器

13. 总结二进制日志的不同格式的使用场景。

基于"语句"记录:statement    记录语句,日志量较少
基于"行"记录:row    记录数据,日志量较大,更加安全,日志文件体积大
混合模式:mixed    数据库系统自行判断

14. 总结mysql备份类型,并基于mysqldump, xtrabackup完成数据库备份与恢复验证。

备份类型:
    完全备份:备份整个数据集
    部分备份:只备份数据子集,如部分库和表
    增量备份:仅备份最近一次完全备份或增量备份(如果存在增量)以来变化的数据,备份较快,还原复杂
    差异备份:仅备份最近一次完全备份以来变化的数据,备份较慢,还原简单

mysqldump工具备份还原:

模拟删库,删除hello库
使用mysqldump工具还原hello库
删除的数据库已恢复,hello库已恢复

xtrabackup工具备份还原:

xtrabackup工具是第三方工具,需要下载rpm包
rpm包下载到本地后使用yum安装
将原主机数据集备份到/backup目录下
将备份数据集复制到目标主机当前目录下
需要先将目标主机的MySQL服务关闭,清空mysql数据目录下的内容,否则备份完毕后无法启动服务
预准备:确保数据一致,提交完成的事务,回滚未完成的事务
复制数据集到数据库目录
更改目录的属主和属组,然后重启MySQL服务,登录数据库查看备份结果

15. 编写crontab,每天按表备份所有mysql数据。将备份数据放在以天为时间的目录下。基于xtrabackup,每周1,周5进行完全备份,周2到周4进行增量备份

按表备份
每天1点执行crontab
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容