惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Attack and Defense Labs
Attack and Defense Labs
The GitHub Blog
The GitHub Blog
C
Check Point Blog
博客园_首页
MongoDB | Blog
MongoDB | Blog
N
Netflix TechBlog - Medium
F
Full Disclosure
Microsoft Security Blog
Microsoft Security Blog
爱范儿
爱范儿
Recent Announcements
Recent Announcements
阮一峰的网络日志
阮一峰的网络日志
G
GRAHAM CLULEY
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
T
Threat Research - Cisco Blogs
C
Cybersecurity and Infrastructure Security Agency CISA
V
Vulnerabilities – Threatpost
K
Kaspersky official blog
博客园 - 司徒正美
S
Schneier on Security
T
The Exploit Database - CXSecurity.com
Project Zero
Project Zero
云风的 BLOG
云风的 BLOG
Cisco Talos Blog
Cisco Talos Blog
Know Your Adversary
Know Your Adversary
雷峰网
雷峰网
V
V2EX - 技术
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Spread Privacy
Spread Privacy
罗磊的独立博客
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
S
Security Affairs
SecWiki News
SecWiki News
Schneier on Security
Schneier on Security
O
OpenAI News
Jina AI
Jina AI
PCI Perspectives
PCI Perspectives
Cyberwarzone
Cyberwarzone
Y
Y Combinator Blog
Apple Machine Learning Research
Apple Machine Learning Research
B
Blog RSS Feed
I
InfoQ
D
Docker
P
Palo Alto Networks Blog
Recorded Future
Recorded Future
M
MIT News - Artificial intelligence
博客园 - Franky
B
Blog
Scott Helme
Scott Helme
博客园 - 叶小钗
D
DataBreaches.Net

博客园 - Mr.Myth

percona server 二进制安装下编译tpcc-mysql的坑 Problems with MMM for mysql(译文) MySQL MMM 双主在Failover时挂起 Steve Loughran:Why not raid 0,its about time and snowflakes!!! How to Clean Up After a Failed 10g or 11.1 Oracle Clusterware Installation [ID 239998.1] MySQL 5.5 外键不能引用分区表主键 MYSQL 登录漏洞,Percona Server说明 基于xtrabackup的Point-In-Time Recovery备份恢复 五月第二周 合肥之行 ORACLE 10G & patch下载地址大全 RED HAT ES 5.4 X64安装ORACLE 10G R2 64bit - Mr.Myth vmware server 安装oracle 10G RAC 实践(三) vmware server 安装oracle 10G RAC 实践(二) vmware server 安装oracle 10G RAC 实践(一) - Mr.Myth 内存数据库 Timesten - Mr.Myth IBM 中国研究院 Offer 之感言——能力是一种态度(转) XX项目----记录(一) 10G 更改IP地址或机器名后EM配置
使用折半查找法删除
Mr.Myth · 2012-05-23 · via 博客园 - Mr.Myth

DELIMITER //
DROP PROCEDURE IF EXISTS `PRO_BinarySearch_DeleteData` ;
CREATE PROCEDURE PRO_BinarySearch_DeleteData(IN p_tab VARCHAR(50),IN p_key1  VARCHAR(30), IN p_key2 VARCHAR(30),IN p_date DATETIME)
BEGIN
/*折半查找最大主键ID*/
/*Auther:Gerald*/
SET @v_str =
CONCAT('select 
    max(
',p_key1,') into @v_maxid 
from 
    
',p_tab);
    
PREPARE stmt FROM @v_str;
EXECUTE stmt;

SET @v_str=
CONCAT('SELECT 
    min(
',p_key1,') INTO @v_minid 
FROM 
    
',p_tab);

PREPARE stmt FROM @v_str;
EXECUTE stmt;

SELECT UNIX_TIMESTAMP(p_date) INTO @v_date;

SET @v_id=@v_minid;
WHILE @v_minid<=@v_maxid DO 
    SELECT CEIL((@v_minid+@v_maxid)/2INTO @v_midid;
    SET @v_str =CONCAT('select ',p_key2,' into @v_created_at from ',p_tab,' where ',p_key1,'>=@v_midid order by 1 limit 1');
    
    PREPARE stmt FROM @v_str;
    EXECUTE stmt;

    /*right*/
    IF @v_created_at<=@v_date THEN 
    SET @v_minid=@v_midid+1;
    END IF;
    
    /*left*/
    IF @v_created_at>=@v_date THEN
    SET @v_maxid=@v_midid-1;
    END IF;
END WHILE;

/*分批次删除历史数据*/
SET @rowcnt=0;
START TRANSACTION;
cursor_loop:LOOP
    set @v_str =CONCAT('DELETE FROM ',p_tab,' WHERE ',p_key1,'=',@v_id);
    PREPARE stmt FROM @v_str;
    EXECUTE stmt;
    
    SET @rowcnt=@rowcnt+1;
    IF @rowcnt=1000 THEN
        SET @rowcnt =0 ;
        COMMIT;
        START TRANSACTION;
    END IF ;
    SET @v_id=@v_id+1;
    IF @v_id > @v_midid THEN
        LEAVE cursor_loop ;
    END IF ;
END LOOP cursor_loop ;
COMMIT ;

SELECT @v_midid;
END;
//

DELIMITER  ;