> 데이터 베이스 > MySQL 튜토리얼 > MySQL을 사용하여 데이터 보관 테이블을 생성하여 데이터 보관 기능 구현

MySQL을 사용하여 데이터 보관 테이블을 생성하여 데이터 보관 기능 구현

WBOY
풀어 주다: 2023-07-01 17:43:37
원래의
2163명이 탐색했습니다.

MySQL을 사용하여 데이터 보관 테이블을 생성하여 데이터 보관 기능 구현

데이터 보관이란 오래된 데이터를 기록 보관 테이블로 이동하여 기본 데이터베이스 테이블의 고성능을 유지하는 것을 의미합니다. 데이터 아카이빙은 대용량 데이터를 처리할 때 효과적인 데이터 관리 방법입니다. MySQL은 데이터 보관을 구현하는 다양한 방법을 제공하며 그 중 하나는 데이터 보관 테이블을 생성하는 것입니다. 이 기사에서는 MySQL을 사용하여 데이터 보관 테이블을 생성하여 데이터 보관 기능을 구현하는 방법을 소개합니다.

  1. 메인 테이블 만들기
    먼저 현재 활동 데이터를 저장할 메인 테이블을 만들어야 합니다. 이 메인 테이블은 읽기 및 쓰기 작업에 사용되므로 높은 성능을 유지할 수 있습니다. 예를 들어 기본 테이블 구조는 다음과 같습니다.
CREATE TABLE main_table (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(100),
    age INT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
로그인 후 복사
  1. 기록 테이블 생성
    다음으로, 보관된 오래된 데이터를 저장할 기록 테이블을 생성해야 합니다. 이 기록 테이블은 읽기 전용이므로 콜드 스토리지나 아카이브 스토리지와 같은 속도가 느린 저장 매체에 저장할 수 있습니다. 다음은 기록 테이블 구조의 예입니다.
CREATE TABLE archive_table (
    id INT PRIMARY KEY,
    name VARCHAR(100),
    age INT,
    created_at TIMESTAMP
);
로그인 후 복사
  1. Create Archive Stored Procedure
    다음 단계는 기본 테이블에서 기록 테이블로 데이터를 이동하는 저장 프로시저를 만드는 것입니다. 다음은 아카이브 저장 프로시저의 예입니다.
delimiter //

CREATE PROCEDURE archive_data()
BEGIN
    DECLARE done INT DEFAULT 0;
    DECLARE id INT;
    DECLARE name VARCHAR(100);
    DECLARE age INT;
    DECLARE cur CURSOR FOR SELECT id, name, age FROM main_table WHERE created_at < DATE_SUB(CURDATE(), INTERVAL 1 YEAR);
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
    
    OPEN cur;
    
    read_loop: LOOP
        FETCH cur INTO id, name, age;
        IF done THEN
            LEAVE read_loop;
        END IF;
        
        INSERT INTO archive_table (id, name, age, created_at) VALUES (id, name, age, NOW());
        DELETE FROM main_table WHERE id = id;
    END LOOP;
    
    CLOSE cur;
END //

delimiter ;
로그인 후 복사

이 저장 프로시저는 기본 테이블에서 1년 전 데이터를 쿼리하여 기록 테이블에 삽입합니다. 삽입이 성공하면 해당 데이터가 기본 테이블에서 삭제됩니다.

  1. 보관을 위한 예약 작업 설정
    데이터 보관을 자동화하기 위해 정기적으로 보관 저장 프로시저를 호출하는 예약 작업을 설정할 수 있습니다. 다음은 예약된 작업 설정의 예입니다.
CREATE EVENT archive_data_event
ON SCHEDULE
    EVERY 1 DAY
    STARTS '2022-01-01 00:00:00'
DO
    CALL archive_data();
로그인 후 복사

이 예약된 작업은 하루에 한 번 아카이브 저장 프로시저를 실행합니다.

  1. 데이터 보관 기능 테스트
    마지막으로 데이터 보관 기능을 테스트해보겠습니다. 기본 테이블에 일부 데이터를 삽입하고 하루를 기다립니다. 다음 날 예약된 작업이 트리거되어 1년 전의 데이터를 기록 테이블로 이동합니다.
INSERT INTO main_table (name, age) VALUES ('John', 25);
INSERT INTO main_table (name, age) VALUES ('Emily', 30);

-- 等待一天

SELECT * FROM main_table; -- 返回空结果,数据已归档到历史表

SELECT * FROM archive_table; -- 返回归档的数据
로그인 후 복사

위의 과정을 통해 MySQL을 이용하여 데이터 아카이빙 테이블을 성공적으로 생성하고 데이터 아카이빙 기능을 구현했습니다. 데이터 보관은 기본 테이블의 고성능을 유지하고 쿼리 및 분석 요구 사항에 따라 기록 테이블에 콜드 데이터를 저장하는 데 도움이 될 수 있습니다.

위 내용은 MySQL을 사용하여 데이터 보관 테이블을 생성하여 데이터 보관 기능 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿