首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

删除表时是否删除临时表上的索引?

删除表时,根据表的类型(临时表、普通表等),是否删除临时表上的索引取决于您要删除的操作类型和索引的类型。

如果删除的是一个普通表上的索引,那么索引和表本身都会被一起删除。因此,在执行 DELETE FROM tableName 语句时,SQL 引擎会在同时删除临时表上的索引。

如果删除的是一个临时表上的索引,那么 SQL 引擎会删除临时表上的索引,但不会删除该索引对应的普通表上的索引。这是因为临时表本身是为了某个操作(如查询)而创建的,它的出现和消失是由操作执行的。

如果您要删除表,您应该先确定该表是一个普通表还是一个临时表,然后根据上述情况进行索引的删除操作。

如果您需要创建索引来优化某个操作的性能,您可以使用 CREATE INDEX 语句来为一个或多个列创建索引。注意,如果您正在创建一个临时表上的索引,则应该在执行某个操作后删除这个索引,以便 SQL 引擎能够优化数据库的性能。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL 临时表的建立及删除临时表的使用方式

MySQL 临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。...临时表在MySQL 3.23版本中添加,如果你的MySQL版本低于 3.23版本就无法使用MySQL的临时表。不过现在一般很少有再使用这么低版本的MySQL数据库服务了。...如果你退出当前MySQL会话,再使用 SELECT命令来读取原先创建的临时表数据,那你会发现数据库中没有该表的存在,因为在你退出时该临时表已经被销毁了。...---- 删除MySQL 临时表 默认情况下,当你断开与数据库的连接后,临时表就会自动被销毁。当然你也可以在当前MySQL会话使用 DROP TABLE 命令来手动删除临时表。...以下是手动删除临时表的实例: mysql> CREATE TEMPORARY TABLE SalesSummary ( -> product_name VARCHAR(50) NOT NULL

10.8K11

MySQL如何删除#sql开头的临时表

原因 如果MySQL在一个 ALTER TABLE操作(ALGORITHM=INPLACE)的中间退出,那么可能会留下一个占用系统空间的临时表。...例如,在对一张表(大表)添加索引时中途中断、磁盘不足导致异常或正在添加索引时实例被kill等等情况所致。...3.2 创建新表方式删除 因为本例中没有存在.frm 和.ibd名称相同的文件的情况,因此采用创建一张与ibd表空间对应的结构(字段名及索引)一致的表,然后将frm文件拷贝为和ibd一致的文件,再进行删除...[root@db4 testdb]# cp -p company20191216.frm \#sql-ib1516-2335726735.frm c) 删除表 因为上一步拷贝时使用-p的方式,即权限和原文件权限一致...注:删除这种100G的表不建议直接删除,而是通过创建硬链接的方式处理。 3.3 修改frm文件名与ibd文件名一致 上一步中删除ibd文件时,其中一个frm也自动删除了。

5.7K20
  • 安全删除MySQL大表(上)

    一.简介 源码地址 日期:2018/4/12 介绍:工具用于安全删除MySQL表,对于一些特定场景可能有用 应用场景:大批删除不走索引但是有主键的场景[可以是单列索引,也可是多列索引] 实现思路:根据where...条件获取到主键值,然后重新拼接SQL 注:本工具仅用于学习,如用于生产,请充分测试 效果图: image.png 二.使用 适用:centos6+ 语言:中文 注意:必须有主键或者非空唯一索引 1.下载...git clone https://gitee.com/mo-shan/safe_delete.git cd safe_delete 2.配置,将这里的mysql_path改成mysql工具的绝对路径...*#mysql_path=\"/mysqlbinlog_path\"#g' bin/safe_delete 将这里的safe_delete_path改成safe_delete的家目录的绝对路径 sed

    4.6K20

    Oracle分区表删除分区数据时导致索引失效解决

    一、描述       今天有个小任务就是要删除些数据,哈哈,先自己小开心一下。因为要删除的数据表是我之前转换成的分区表。这个分区表是按照里面有个创建时间字段来分区的,1个季度为1个分区。...所以我现在要将2017年7月1日之前的数据删除(数据量约1000万),可以直接删除表分区数据就好。如果要是用delete去删除这么多的数据,我还要写存储过程,分批提交的这样做。...就是这样的一简单的truncate partition 引发了后继的业务故障。最终查询到该表的索引失效,重建立后恢复。真是汗!...,答案是肯定的,删除分区,索引仍然失效。...通过失误,也让我看到了自己对知识点掌握上的不足。以后的路还很远,振作起来,努力学习吧。让自己在后面的DB生涯中,少范错误,多多提高效率。

    2.6K10

    取消显示Windows文件删除时“是否删除”的提示

    本文介绍Windows电脑在删除资源管理器中的文件时,开启显示或取消显示确认删除这一二次提示弹窗的具体方法。   ...在Windows电脑中,我们删除任何一个文件时,无论是用鼠标右键选择“删除”选项,还是用快捷键Ctrl与D对文件加以删除,默认情况下都会有一个名为“删除文件”的提示框,询问你是否确认要将该文件放入回收站...完成以上操作后,我们再在电脑中删除文件,在鼠标右键选择“删除”选项后,亦或是在用快捷键Ctrl与D后,该文件就会直接进入回收站,不会再出现本文开头所示的那个“删除文件”提示框了。...这样子,在部分场景下,可以显著提高我们的文件管理效率;如果我们后续需要将文件重新恢复,还是可以在回收站中找到删除的文件,并将其还原的。   ...此外,我们还可以在上图中间位置的“选定位置的设置”一栏,勾选其中的第二个选项,这样以后删除文件就会直接让该文件从电脑中消失,不再放入回收站。

    6600

    MySQL在删除表时IO错误原因分析

    insert buffer背景知识 insert buffer是一种特殊的数据结构(B+ tree),当辅助索引页面不在缓冲池中时,它会将更改缓存起来,稍后在页面被其他读取操作加载到缓冲池中时合并。...先判断过去1s之内服务器是否发生过活动(插入元组到页面、undo表上的行操作等),如果发生过,则merge的最大页面数为innodb_io_capacity设定的5%。...如果检测到大于0,意味着还有依赖的I/O未完成,睡眠20ms后重试; 此时认为已经没有冲突的操作了,刷出所有脏页面或删除所有给定的表空间的页面; 从表空间缓存删除指定space的记录; 删除对应数据文件...两线程的交互如下图所示: ? 不出意外的话,在打中断点时必然有线程在执行对应表的删除操作。...的space id,如果space id是相同的,直接删除对应ibuf的记录(当前分配的最大space id记录在系统表空间,space id占4个字节,低于0xFFFFFFF0UL,分配时读取系统表空间保存的值

    1.9K20

    MySQL 超大表的删除方法

    MySQL里面直接对大表执行drop table删除有可能导致mysql hang住。必须使用些特殊的方法。 先搞一个大表出来,如下图: ? 可以看到t2表的ibd大小为2.7GB了 ?...创建一个硬链接的好处就是: 硬链接就是增加了对文件的引用,只有对磁盘上文件的引用完全没有了的话,这个文件才能是删除的。...我们对t2.ibd 建立硬链接后,当我们执行drop table t2; 的时候,实际上只是删除了对t2.ibd的一个文件引用,我们t2.ibd_hdlk对物理文件的引用还是存在的,就不会执行OS级别的删除操作...2、执行实际的删除 droptable test.t2; 3、使用coreutils工具集执行OS级别的文件删除 下载地址: ftp://alpha.gnu.org/gnu/coreutils/ tar...这个小文件我们直接使用rm删除即可。 ? 这样就彻底删除掉这个t2大表了。

    6.9K50

    MySQL表删除数据,索引文件会不会变小?

    这篇文章又让我了解到:原来删除数据,表的空间是不会释放的... 一张千万级的数据表,删除了一半的数据,你觉得B+树索引文件会不会变小? 我们先来做个实验,看看表的大小是如何变化的??...开始时user表有1000W条数据,删除若干后,目前剩余约 550W 条 5、在删除约500W条记录后,再次查看表文件大小 ?...索引文件大小约 595 M,最后修改时间 10:34 实验结论: 对于千万级的表数据存储,删除大量记录后,表文件大小并没有随之变小。好奇怪,是什么原因导致的?...但是,如果修改的内容包含了索引,那么操作步骤是先删除一个旧的值,然后再插入一个新值。可能会造成空洞。 分析发现,新增、修改、删除数据,都可能造成表空洞,那么有没有什么办法压缩表空间?? ?...用临时文件替换表A的数据文件 删除旧的表A数据文件 与新建表的最大区别,增加了日志文件记录和重放功能。

    2.9K51

    MySQL异步删除大表的方法

    table命令.deletedelete命令逐行删除数据,涉及行锁,删除多条数据时性能差.dropdrop命令会删除表数据及结构、触发器、分区等。...truncate只能作用于表;delete,drop可作用于表、视图等。truncate会清空表中的所有行,但表结构及其约束、索引等保持不变;drop会删除表的结构及其所依赖的约束、索引等。...truncate后会使表和索引所占用的空间会恢复到初始大小;delete操作不会减少表或索引所占用的空间,drop语句将表所占用的空间全释放掉。...因此,可以通过分批delete的方式,建议where条件中最好带上主键或者是索引,加速删除的效率。但对于大表来说,这种方式性能太低。...,由内核自动完成,其原理是在删除表时,为表的数据文件在另外一个目录中创建一个硬连接。

    4.5K110

    SQL:删除表中重复的记录

    ,这里是name) select distinct (name) into # from test --查看新表中的数据 select from # --清空旧表 truncate table test...--将新表中的数据插入到旧表 insert test select from # --删除新表 drop table # --查看结果 select from test 查找表中多余的重复记录...peopleId in (select  peopleId  from  people  group  by  peopleId  having  count(peopleId) > 1)  2、删除表中多余的重复记录...a.peopleId,a.seq) in  (select peopleId,seq from vitae group by peopleId,seq  having count() > 1)  4、删除表中多余的重复记录...“name”,而且不同记录之间的“name”值有可能会相同,  现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;  Select Name,Count() From A Group

    4.8K10

    MySQL 批量删除表的实现方式

    在实际应用中,有时候需要批量删除以特定前缀命名的表(如数据清理或数据处理时生成的临时表)。这里分享实现这一功能的方法和注意事项,以便避免实现过程中出现问题。...基本思路 使用 information_schema.tables 获取相关表名。 根据表名生成 DROP TABLE 语句。 通过动态 SQL 或采用流转一个一个删除。...使用动态 SQL 批量删除表 这个方法适合对表量较少的情况: -- 增大 GROUP_CONCAT_MAX_LEN 以防止 SQL 超长 SET SESSION group_concat_max_len...使用流转逐表删除 这个方法适合对表量较多的情况,通过流转一个一个删除: -- 先删除已存在的存储过程 DROP PROCEDURE IF EXISTS DropTablesWithPrefix; --...deleting table {table_name}: {err}") # 提交并关闭连接 conn.commit() cursor.close() conn.close() 总结 在使用 MySQL 批量删除表时

    11710

    【SQL】进阶知识 -- 删除表的几种方法(包含表内单个字段的删除方法)

    第一部分:删除整个表 1.1 DROP语句 — “彻底清除” 当你需要完全删除一个表及其所有数据时,DROP TABLE 语句就是你的好朋友。...2.1 ALTER TABLE 语句 — “修改结构,轻松删除列” ALTER TABLE 语句允许你修改表的结构,包括删除不需要的列。删除列时,原列中的所有数据都会丢失。...注意: 删除列时,表中的所有数据会丢失,因此要确保你已经备份了重要的数据!删除操作无法恢复。...删除单个字段时,记得检查表是否会影响到其他依赖此列的约束。 总结 到这里,我们已经介绍了SQL中几种常见的删除方法。从删除整个表,到清空表中的数据,再到删除表中的单个字段,我们都有详细的解释和示例。...掌握这些删除操作后,你就能更加灵活地管理你的数据库,清理不需要的数据和结构。 下次当你遇到不需要的表或者字段时,你就可以大胆地删除它们啦!

    14400

    ②【MySQL表操作】 数据库表的创建、查询、修改、删除

    个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 数据库表的创建、查询、...tb_emp CHANGE nickname username VARCHAR(30); ③删除字段 ALTER TABLE 表名 DROP 字段名; -- 案例 -- 将tb_emp表的字段username...删除 ALTER TABLE tb_emp DROP username; ④修改表名 ALTER TABLE 表名 RENAME TO 新表名; 删除表操作: ①删除表 DROP TABLE [IF EXISTS...] 表名; -- 演示 -- 删除名为aaa的表 -- 执行时,如果aaa表不存在,报错: -- 错误代码: 1051 Unknown table '表名' DROP TABLE aaa; -- 使用关键字...IF EXISTS -- 当要被删除表不存在时,不会再删除,也不会报错 DROP TABLE IF EXISTS aaa; ②删除指定表,并重新创建该表 TRUNCATE TABLE 表名;

    52950

    Mysql删除满足自己某个条件的表

    问题描述: 自循环删除,大概意思就是删除一个表里的部分数据,这些数据所满足的条件也在自己表里 ,我有点儿晕,直接上代码,这是select出来的,正常流程,如果要删除直接改成delete from …就行了...错误代码: 1093 You can't specify target table '表名' for update in FROM clause 其实仔细想想逻辑还是有问题的,循环用了同一张表,会形成类似于死循环的操作...,虽然我们明白这样好像没什么问题,但是电脑和你不一样, mysql在把子查询结果作为删除表中数据的条件,而mysql不允许在子查询的同时删除原表数据 解决办法: 方法一、分步骤: 先创建临时表 create...table tmp(SELECT DISTINCT 统计日期 FROM 表名 WHERE 字段1='data1') 再执行删除 delete FROM 表名 WHERE 统计日期 IN(SELECT...* FROM tmp) AND 字段1 'data1' 最后删除临时表 drop table tmp 方法二直接删除 链接:https://blog.csdn.net/jaryle/article

    2.7K20
    领券