mysql delete 数据库数据走索引吗

推荐这篇日记的豆列
&&&&&&&&&&&&mysql force index强制指定索引 - 为程序员服务
为程序员服务
mysql force index强制指定索引
mysql可以通过force index关键字强制指定查询使用某个索引,如下sql语句:
select a.* from mvn_artifact a force index(IX_Path)
inner join (select artifactPath from mvn_artifact_tag where tagId = 361) as ap
on a.path like concat(ap.artifactPath,'%')
order by a.lastModifiedTime desc
limit 0,20
在mvn_artifact a后面用 force index(IX_Path)强制指定使用索引IX_Path.
您可能的代码
相关聚客文章
荣誉:1350
相关专栏文章mysql 如何用命令清除表数据,让表数据索引是从0开始呢?_百度知道
mysql 如何用命令清除表数据,让表数据索引是从0开始呢?
mysql 如何用命令清除表数据,让表数据索引是从0开始呢?一般用 delete from MYTABLE这可以清除数据,但是索引回不去了,怎么才能“完全”清除表数据呢?不要说删除表再建哦。希望有高手能解决!
我有更好的答案
truncate MYTABLE
这样就可以了 其实这个命令就相当于删除表再建 所有的数据都还原
采纳率:47%
truncate MYTABLE
为您推荐:
其他类似问题
您可能关注的内容
mysql的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。boss_t_tour表目前有150W数据,其中出现了15000多条有重复记录的数据,需要删除其中的8000多条多余的记录。
如果删除小表,不担心效率,可以用下面方式删除,
但是用上面的sql如果想在大表操作删除,肯定是不行的。
查看表中imsi除了空以外重复的数目。
SELECT COUNT(t.`imsi`),t.`imsi` FROM `boss_t_tour` t WHERE t.imsi && ''
GROUP BY t.`imsi` HAVING COUNT(t.`imsi`) &1
mysql大数据表中的快速删除部分数据办法:
1.创建删除重复的存储过程
DELIMITER $$
USE `bossdb` $$
DROP PROCEDURE IF EXISTS `del` $$
CREATE DEFINER = `root` @`localhost` PROCEDURE `del` ()
/** 定义后面循环用到的变量*/
DECLARE coun1 INT ;
DECLARE count2 INT ;
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
/** 创建临时表*/
CREATE TABLE tmp_imsi AS SELECT t.imsi AS imsi FROM boss_t_tour t WHERE t.imsi && '' GROUP BY t.imsi HAVING COUNT(t.imsi) &1;
CREATE TABLE tmp_all AS SELECT t.id,t.imsi AS imsi FROM boss_t_tour t WHERE t.imsi IN (SELECT imsi FROM tmp_imsi);
CREATE TABLE tmp_keep AS SELECT MIN(a.id) AS id FROM tmp_all a GROUP BY a.
CREATE TABLE tmp_delete AS SELECT a.id AS id FROM tmp_all a WHERE a.id NOT IN (SELECT id FROM tmp_keep) ;
/** 先删除索引提高删除速度*/
ALTER TABLE `bossdb`.`boss_t_tour`
DROP INDEX `imsi_index`,
DROP INDEX `syncstatusInded`;
/** 循环删除开始*/
/** 原计划用此子查询删除,DELETE FROM boss_t_tour WHERE EXISTS (SELECT 1 FROM tmp_delete WHERE boss_t_tour.id = tmp_delete.id);*/
/** 但是发现mysql子查询删除效率奇慢,本机测试主表150W数据 临时表8000条数据 删除3000条用了一个小时,效率太差不敢在生产环境使用。*/
/** 用下面的循环删除效率高很多,删除8000多条数据5分钟 */
SELECT COUNT(*) INTO coun1 FROM tmp_
WHILE coun1 & 0 DO
SELECT id INTO count2 FROM tmp_delete LIMIT 1 ;
DELETE FROM boss_t_tour WHERE id = count2 ;
DELETE FROM tmp_delete WHERE id = count2 ;
SET coun1 = coun1 - 1 ;
END WHILE ;
/** 循环删除结束*/
/** 重建索引*/
ALTER TABLE `bossdb`.`boss_t_tour`
INDEX `imsi_index` (`imsi`),
INDEX `syncstatusInded` (`sync_status`);
/** 删除临时表*/
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
DROP TABLE IF EXISTS tmp_
DELIMITER ;
2.执行存储过程
CALL del();
本机执行5分钟完成。
写的过程中还发现个问题mysql的delete操作居然不能给 表定义别名。。。
MYSQL delete语句不支持别名?
seaboycs 写道当你的数据达到千万,亿级别时删索引就要花你太多太多时间。先建表,倒过来数据后再建索引就块多了mysql文档有一种解决方案,数据量级别太大目前的mysql貌似只能用建个新表再重命名。建个新表,把要保留的数据存进去,再删了之前的表,把新表重命名成老表的名字。再建索引。
当你的数据达到千万,亿级别时删索引就要花你太多太多时间。先建表,倒过来数据后再建索引就块多了
浏览: 196266 次
来自: 杭州
kidding87 写道seaboycs 写道当你的数据达到千 ...
seaboycs 写道当你的数据达到千万,亿级别时删索引就要花 ...
当你的数据达到千万,亿级别时删索引就要花你太多太多时间。
我们的项目Repository就是放在D盘根目录里面,按理来说 ...
东软早已经被我们院列到求职公司黑名单了...
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'

我要回帖

更多关于 mysql delete 表数据 的文章

 

随机推荐