首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL库到跑路(一)——MySQL数据库简介

MySQL是一个关系型数据库管理系统,MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,就增加了速度并提高了灵活性。...   H、提供用于管理、检查、优化数据库操作的管理工具    I、可以处理拥有上千万条记录的大型数据库 3、MySQL应用 与大型数据库例如Oracle、DB2、SQL Server等相比,MySQL...MyISAM不支持事务、也不支持外,但其访问速度快,对事务完整性没有要求。 InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。...MySQL支持外存储引擎只有InnoDB,在创建外的时候,要求附表必须有对应的索引,子表在创建外的时候也会自动创建对应的索引。...所以如果应用不需要事务,不支持外,处理的只是基本的CRUD(增删改查)操作,那么MyISAM是不二选择。

2K20

数据库MySQL进阶一、主外讲解

MySQL进阶主外讲解 1.什么是外: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外:是另一表的主键, 外可以有重复的, 可以是空值,用来和其他表建立联系用的...所以说,外一定是在从表中创建,从而找到与主表之间的联系;从表负责维护二者之间的关系。 2.外的使用需要满足下列的条件:(这里涉及到了InnoDB的概念) 1....注:InnoDB是数据库的引擎。MySQL常见引擎有两种:InnoDB和MyISAM,后者不支持外。 2. 建立外关系的对应列必须具有相似的InnoDB内部数据类型。...建立外关系的对应列必须建立了索引。 4. 假如显式的给出了CONSTRAINT symbol,那symbol在数据库中必须是唯一的。假如没有显式的给出,InnoDB会自动的创建。...面试题:你的数据库用什么存储引擎?区别是? 答案:常见的有MyISAM和InnoDB。 MyISAM:不支持外约束。不支持事务。

2K70

Mysql库到跑路 基于mysql8 MYD MYI SDI数据库恢复

Mysql是最常见的关系数据库,因开源和免费被广泛使用。如果当我们数据库误删后,在没有备份的情况下如何恢复数据库呢?...image.png Mysql8.0数据库恢复 环境 Windows Linux Mysql8.0.12 PHP7.4 Dzx3.4 故障描述 有网友联系我,说自己的dz站不小心库了!...在查阅一番后,知道了自Mysql8.0后,当用户创建了数据库后,会在MySQL8.0.12\data目录下产生相应的恢复文档,用于后期的恢复!当然Mysql之前的版本也有这个功能,但是文件格式变了!...文件 说明 XXX.sdi 表结构文件 XXX.MYD 数据文件 XXX.MYI 索引文件 我们可以利用这三个文件完成对数据库的恢复 image.png 库恢复测试 1.我们首先创建一个数据库bbskali...image.png 7.重启数据库,就可以看到数据已恢复! Dz3.4库恢复 基于上面的恢复策略,我们可以去恢复误删的dz的数据库

2.8K30

MySQL - 库了,但是很慢

mysql 上执行了一句 drop database 半天没有完成,详细的慢查询日志如下,那当时MySQL 在做什么呢?...如果我们从 linux 内核层面看,还是可以发现 mysql 这个时候在执行哪些函数的;从而达到更加细粒度的确认 MySQL 在做什么,进而回答 drop database 为什么慢。...可以看到在库时调用的是 mysql_rm_db 这个函数,而这个函数又调用了 mysql_rm_table_no_locks 函数,mysql_rm_table_no_locks 会去清理数据字典。...那库为什么会慢呢?回答这个问题还需要更加深入地分析才行。 ---- OFF-CPU 如果一个进程所依赖的所有资源都已经准备好,那它就可以被调度到 cpu 上执行。...我在分析清理文件的时候发现 vfs 并没有 rm_file 这样的 API ,而是采用“以写代” 的方式来完成删除操作; 也就是说操作系统并不直接去删除文件,而是把文件系统里面对应的 inode 标记为

2.3K20

MySQL系列】- binlog预防库跑路

. ❞ 翻译:二进制日志包含描述数据库更改的“事件”,如表创建操作或表数据更改。...说白了就是二进制日志记录了对 MySQL 数据库执行更改的所有操作,若操作本身没有导致数据库发生变化,该操作可能也会写入二进制文件。...这些事件使数据库从备份点更新,数据将变化恢复到指定的时间点(Point-in-time)。...主从复制(replication):主数据库向从数据库发送binlog到从数据库,从数据库执行和复制binlog从而将数据恢复到从数据库中。...审计(audit):用户可以通过二进制日志中的信息来进行审计,判断是否有对数据库进行注入的攻击。 binlog的格式 MySQL有好3种格式记录binlog,具体的格式取决于MySQL数据库的版本。

77830

库跑路?这篇文章教你如何使用xtraback备份MySQL数据库

最大的缺陷就是备份和恢复的速度都慢,对于一个50G的数据库而言,这个速度还是可以接受的,但是如果数据库非常大,那在使用mysqdump备份就不是太合适了。。...至此全备完全成功,然后向mysql某个库插入几条数据,然后进行增量备份 对完全备份的后数据库更改进行二进制日志增量备份: 查看完全备份时binlog日志位置(position): ?... > /opt/mysqlbackup/inc/`date +%F`.sql  备份完成后,我们模拟数据库损坏,误删操作,如下 [root@master ~]# rm -rf /usr/local/mysql...如: # chown -R mysql:mysql /usr/local/mysql/data/  重启mysql服务查看是否还原成功 ?...停止mysql数据库-开始rsync数据文件 [root@master ~]# systemctl stop mysqld   [root@master ~]# cd /opt/mysqlbackup

59510

【玩转腾讯云】使用数据库Mysql如何避免库跑路(数据丢失)

生产环境使用数据库最怕的就是数据丢失了,下面针对各种数据丢失场景展开。 场景一:人为操作引起,包括:故意的库跑路、手抖误操作。...所以不要用云服务器自建数据库,而是直接使用云数据库,云数据库已经把这些都做好了,没必要去把别人踩过的坑再踩一遍。 做好监控,第一时间发现事故。...为了恢复数据时好恢复,表结构不要使用外约束、日常最好不要跨表操作。 生产环境操作,需要在业务低谷时段操作。如果误操作需要恢复,对用户影响最小。...同样的,我们不能假设腾讯云可靠性达到100%,需要考虑腾讯云出故障了、腾讯云dba库跑路、或者某个潜藏的bug未来某个时段爬起来库。...比如:现在(2020-04-18),腾讯云就有安全漏洞,web用户可以通过销毁/退货+立即下线将主实例、相关的只读实例、灾备实例、自动冷备文件全部删掉(1个冷备文件是无法操作的,全部数据却可以操作)

7.7K3326

mysql 分区_mysql分区

分区 就访问数据库的应用而言,逻辑上只有一个表或一个索引,但是实际上这个表可能由数10个物理分区对象组成,每个分区都是一个独立的对象,可以独自处理,可以作为表的一部分进行处理。...对于已经过期或者不需要保存的数据,可以通过删除与这些数据有关的分区来快速删除数据 跨多个磁盘来分散数据查询,以获得更大的查询吞吐量 分区:partition key 查看是否支持分区: mysql>...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...例如,上述例子中检索store_id ,大于10的记录,mysql只需要扫描p1 ; 可以使用explain 来检测,查询使用的是哪个分区; List分区: list 分区是建立离散的值列表告诉数据库特定的值属于哪个分区...; 子分区 对分区表中每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式

3.8K30

MySQL中drop和delete用户场景

关于用户创建的文章,之前写过几篇《MySQL创建用户提示1396》《小白学习MySQL - 不同版本创建用户的些许区别》。 碰巧看到技术社群的这篇文章《同样是用户,为啥还有差别?》...在MySQL当中,对于删除用户的操作大家并不陌生,先来看看问题, # 创建用户testuser01 mysql> create user 'testuser01'@'%' identified by '...接着往下看, # 再次删除用户testuser01 mysql> delete from mysql.user where user = 'testuser01'; Query OK, 1 row affected...mysql> flush privileges; Query OK, 0 rows affected (0.01 sec) # 创建用户testuser01成功 mysql> create user '...分析  还是回到这条语句上,这条语句是创建一个用户'testuser01'@'%',在MySQL当中,这条语句在执行器执行时,大致上看成对mysql库的user表插入一条记录,既然是表,大可以先查查看,

17420
领券