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

    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.4K20

    通过Model.remove数据方法

    通过Model.remove方法 现在推荐使用Model.deleteOne Model.deleteMany来删除 用法一样 不传入参数会删除该表的所有数据 该方法返回的是删除数据的条数,不会返回被删除数据...指定要删除数据的某个也可以使用正则表达式 const remove = await User.remove({ name: /\d/ }); 也可以先查找,然后用数据的remove方法 // 可以链式调用...await User.find({ name: "2" }); data.forEach((item) => { item.remove(); }); 通过Model.findOneAndRemove方法...删除符合条件的第一条数据,并将这条数据返回 通过Model.findByIdAndRemove方法 通过_id删除 ---- 改 Model.update已经不支持 通过Model.updateOne...Model.updateMany方法方法返回修改的信息,不是返回修改后的数据 先指定查询的条件,再在第二个参数放入修改的数据,第三个参数为一些设置 const datas = await User.updateOne

    68500

    mysql 分区_mysql分区

    对于已经过期或者不需要保存的数据,可以通过删除与这些数据有关的分区来快速删除数据 跨多个磁盘来分散数据查询,以获得更大的查询吞吐量 分区:partition key 查看是否支持分区: mysql>...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...; 子分区 对分区表中每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式...colulmns (a,b) (partition p01 values less than (ma,mb)); 先比较a,如果a小于ma,则直接存,当a=ma且b 分区管理: range和list:增,,...合并,拆分; 拆分与合并,后范围只能变大,不能缩小; 同时不能与其他分区 重叠,只能够重新定义相邻的分区,不能跳分区进行重定义; hash:,增; 发布者:全栈程序员栈长,转载请注明出处:https:

    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表插入一条记录,既然是表,大可以先查查看,

    18720

    MySQL约束

    关系是关系数据库的重要组成部分。关系是一个表中的一个或几个属性,用来标识该表的每一行或与另一个表产生联系。...其中就包括外 1 主键(primary key或unique key) 又称主码,数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。...而unique key只是为了保证域/域组的唯一性 2 外(foreign key) 又称外部。...注意 : 外不一定要与相应主键同名,只是在应用中为便于识别,当主键与相应外属于不同关系时,往往取同名 作用 保持数据一致性,完整性,主要目的是控制存储在外表中的数据。...使两张表形成关联,外只能引用外表中的列的值或使用空值。 案例 如果不使用外,表2的学号字段插了一个值(比如20140999999),但该值在表1中并没有。

    6.5K20

    mysql的外

    MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外约束。...外的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外(据说以后的版本有可能支持,但至少目前不支持); 2.外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引...,但如果在较早的版本则需要显示建立; 3.外关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 外的好处:可以使得两张表关联...| SET NULL | NO ACTION | SET DEFAULT}] 该语法可以在 CREATE TABLE 和 ALTER TABLE 时使用,如果不指定CONSTRAINT symbol,MYSQL...ON DELETE、ON UPDATE表示事件触发限制,可设参数: RESTRICT(限制外表中的外改动) CASCADE(跟随外改动) SET NULL(设空值) SET DEFAULT(设默认值

    5.5K70

    MySQL库到恢复,还用跑路吗?

    二、 逻辑备份和恢复 在 MySQL 中,逻辑备份的最大优点是对于各种存储引擎都可以用同样的方法来备份;而物理备份则不同,不同的存储引擎有着不同的备份方法,因此,对于不同存储引擎混合的数据库,逻辑备份会简单一点...需要恢复备份: 库跑路: # 这里为了便于测试,不把库操作记入日志,当前 session 设置 sql_log_bin 为 off。...# 库后,执行 flush logs,让后续的 binlog 到新的文件中,即名为 mysql-bin.000003中 MySQL [t2]> set sql_log_bin = 0; Query OK...冷备份 冷备份其实就是停掉数据库服务,cp 数据文件的方法。(基本不考虑这种方法) 2. 热备份 在 MySQL 中,对于不同的存储引擎热备份的方法也有所不同。...常用的有以下两种方法: 使用 mysqlhotcopy 工具 // mysqlhotcopy 是 MySQL 的一个自带的热备份工具 shell> mysqlhotcopy db_name [/path

    1.3K50

    MySQL库到跑路_高级(六)——索引

    MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的。...4、索引的使用原则 A、主键自动建立唯一索引 B、频繁作为查询条件的字段应该创建索引 C、查询中与其他表关联的字段,外关系建立索引 D、频繁更新的字段不适合建立索引,因为每次更新不单单是更新了记录还会更新索引...ref用于连接程序使用的最左前缀或者不是primary key或unique索引的情况。取值有system、const、eq_ref、index和All。...possible_keys:MySQL在搜索数据记录时可以选用的各个索引 key:实际选用的索引 key_len:显示MySQL使用索引的长度(使用的索引个数),当key字段的值为 null时,索引的长度就是...MySQL只需要通过索引就可以返回查询所需要的数据,而不必在查到索引之后进行回表操作,减少IO,提供效率。

    1.2K20
    领券