欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PostgreSQL定時(shí)清理舊數(shù)據(jù)的實(shí)現(xiàn)方法

 更新時(shí)間:2024年03月13日 09:11:14   作者:總比一事無(wú)成的好  
最近覺(jué)得數(shù)據(jù)庫(kù)中每日數(shù)據(jù)不需要都保持,只需要保留30天的,所以這篇文章給大家介紹了PostgreSQL定時(shí)清理舊數(shù)據(jù)的實(shí)現(xiàn)方法,文中通過(guò)代碼示例和圖文給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下

前言

最近leader覺(jué)得數(shù)據(jù)庫(kù)中每日數(shù)據(jù)不需要都保持,只需要保留30天的,就讓我去研究下??邮钦娴拇螅詈蟛琶銖?qiáng)實(shí)現(xiàn),故記錄一下。

技術(shù)涉及:docker docker-conpose SQL pgadmin4 pgagent

環(huán)境說(shuō)明

我們的數(shù)據(jù)庫(kù)是部署是使用docker-conponse直接部署在服務(wù)器上的,默認(rèn)為debain。

postgre為14,所以下面默認(rèn)你已經(jīng)在docker中安裝了數(shù)據(jù)庫(kù)

1、對(duì)原來(lái)的docker—compose進(jìn)行修改

在原來(lái)的基礎(chǔ)上添加:

pgadmin: 
    container_name: pgadmin4_container 
    image: dpage/pgadmin4 
    restart: always 
    environment: 
        PGADMIN_DEFAULT_EMAIL: <admin@admin.com> PGADMIN_DEFAULT_PASSWORD: root 
    ports: - "5050:80"

添加完畢后,重啟下容器

docker-compose up -d

這個(gè)時(shí)候我們?cè)L問(wèn)下服務(wù)器ip:5050就能看到一個(gè)可視化的數(shù)據(jù)庫(kù)管理頁(yè)面

記得在postgres中添加以下sql代碼

CREATE OR REPLACE FUNCTION delete_old_data() RETURNS void AS $$
DECLARE
tbl_name record;
table_date date;
BEGIN
FOR tbl_name IN SELECT table_name FROM information_schema.tables WHERE table_schema = 'public' AND table_name LIKE 'position_record_%' AND table_name ~ '\d{8}' LOOP
table_date := to_date(substring(tbl_name.table_name from '\d{8}'), 'YYYYMMDD');
IF table_date < current_date - 30 THEN
EXECUTE format('DROP TABLE IF EXISTS public.%I', tbl_name.table_name);
END IF;
END LOOP;
END;
$$ LANGUAGE plpgsql;

2、pgadmin基本操作

輸入賬號(hào)和密碼:admin@admin.com、root

登陸成功

(修改中文為:左上角-FILE-Preferences-User language-Chinese)

右擊Servers-創(chuàng)建-服務(wù)器

輸入對(duì)應(yīng)的ip賬號(hào)密碼,就可以看到自己的數(shù)據(jù)庫(kù)了。

3、安裝pgagent插件(重點(diǎn))

你需要進(jìn)入postgres容器、環(huán)境配置、安裝pgagent、pgagent配置

docker-compose exec pgsql bash # 進(jìn)入容器
apt-get update # 更新源
apt install vim # 安裝vim工具
vim /etc/apt/sources.list # 進(jìn)入系統(tǒng)源配置文件把原來(lái)的注釋了添加

deb <http://mirrors.aliyun.com/debian/> bullseye main deb 
<http://mirrors.aliyun.com/debian-security> bullseye-security main deb 
<http://mirrors.aliyun.com/debian> bullseye-updates main
# 修改成國(guó)內(nèi)源

apt-get update
apt install pgagent # 安裝pgagent
psql -U postgres -h localhost # 創(chuàng)建db擴(kuò)展
CREATE EXTENSION pgagent; 
\q 
exit
# 在postgres數(shù)據(jù)庫(kù)上啟用pgagent:
pgagent hostaddr=127.0.0.1 dbname=postgres user=postgres password=***** 
# 和你的docker-conpose保持一致就好

如果輸入pgagent hostaddr...指令沒(méi)有報(bào)錯(cuò)的話就安裝插件完畢了。

這個(gè)時(shí)候你再去訪問(wèn)pgadmin就可以看到

即pgagent配置完畢!

4、定時(shí)任務(wù)的開(kāi)啟和清理的sql語(yǔ)句

鼠標(biāo)右擊pgAgent任務(wù)-創(chuàng)建-pgAgent作業(yè)...

輸入名稱后,點(diǎn)擊步驟

由于我是本地所以連接字符串不需要(按照你的需求來(lái)) 在代碼中添加

SELECT delete_old_data();

這個(gè)清理的具體邏輯按照你實(shí)際情況來(lái)

這樣就是一天執(zhí)行一次,按照你的需求來(lái),如果是小時(shí)為00分鐘為30,那就是到30分鐘就清理一次(一小時(shí))

點(diǎn)擊保存就好了。

這里可以看到配置的狀態(tài)

尾聲

我就是簡(jiǎn)單配置下,看看會(huì)不會(huì)生效。如果可以的話,我將把定時(shí)備份數(shù)據(jù)庫(kù)的操作也放到上面去。如果我上的有錯(cuò),也會(huì)修改。

以上就是PostgreSQL定時(shí)清理舊數(shù)據(jù)的實(shí)現(xiàn)方法的詳細(xì)內(nèi)容,更多關(guān)于PostgreSQL定時(shí)清理舊數(shù)據(jù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • PostGreSql 判斷字符串中是否有中文的案例

    PostGreSql 判斷字符串中是否有中文的案例

    這篇文章主要介紹了PostGreSql 判斷字符串中是否有中文的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-02-02
  • PostgreSQL 修改視圖的操作

    PostgreSQL 修改視圖的操作

    這篇文章主要介紹了PostgreSQL 修改視圖的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL中查看當(dāng)前時(shí)間和日期的幾種常用方法

    PostgreSQL中查看當(dāng)前時(shí)間和日期的幾種常用方法

    在 PostgreSQL 中,有多個(gè)函數(shù)可以用來(lái)查看當(dāng)前時(shí)間和日期,這些函數(shù)在處理時(shí)間戳、日期和時(shí)間的計(jì)算時(shí)非常有用,以下是幾種常用的查看當(dāng)前時(shí)間和日期的函數(shù)及示例,需要的朋友可以參考下
    2024-10-10
  • postgreSQL查詢結(jié)果添加一個(gè)額外的自增序列操作

    postgreSQL查詢結(jié)果添加一個(gè)額外的自增序列操作

    這篇文章主要介紹了postgreSQL查詢結(jié)果添加一個(gè)額外的自增序列操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-02-02
  • 解決PostgreSQL服務(wù)啟動(dòng)后占用100% CPU卡死的問(wèn)題

    解決PostgreSQL服務(wù)啟動(dòng)后占用100% CPU卡死的問(wèn)題

    前文書(shū)說(shuō)到,今天耗費(fèi)了九牛二虎之力,終于馴服了NTFS權(quán)限安裝好了PostgreSQL,卻不曾想,服務(wù)啟動(dòng)后,新的狀況又出現(xiàn)了。
    2009-08-08
  • SQL Server數(shù)據(jù)遷移至PostgreSQL出錯(cuò)的解釋以及解決方案

    SQL Server數(shù)據(jù)遷移至PostgreSQL出錯(cuò)的解釋以及解決方案

    最近對(duì)SQL Server到PostgreSQL的數(shù)據(jù)遷移時(shí)出現(xiàn)了問(wèn)題,返回的錯(cuò)誤為:invalid byte sequence for encoding "UTF8": 0x00。經(jīng)查證pg源代碼,該問(wèn)題引起的原因是sql server的字符類型字段中含有空字符\0,該字符在pg中不支持。
    2014-09-09
  • PostgreSQL 邏輯復(fù)制 配置操作

    PostgreSQL 邏輯復(fù)制 配置操作

    這篇文章主要介紹了PostgreSQL 邏輯復(fù)制 配置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • PostgreSQL使用MySQL作為外部表(mysql_fdw)

    PostgreSQL使用MySQL作為外部表(mysql_fdw)

    PostgreSQL 提供了一種訪問(wèn)和操作外部數(shù)據(jù)源的機(jī)制,稱為外部數(shù)據(jù)包裝器,本文主要給大家介紹了PostgreSQL使用MySQL作為外部表的方法,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • postgresql 刪除重復(fù)數(shù)據(jù)案例詳解

    postgresql 刪除重復(fù)數(shù)據(jù)案例詳解

    這篇文章主要介紹了postgresql 刪除重復(fù)數(shù)據(jù)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 基于PostgreSQL的時(shí)序數(shù)據(jù)庫(kù)TimescaleDB的基本用法和概念

    基于PostgreSQL的時(shí)序數(shù)據(jù)庫(kù)TimescaleDB的基本用法和概念

    時(shí)序數(shù)據(jù)是指按照時(shí)間順序存儲(chǔ)的數(shù)據(jù),TimescaleDB是一個(gè)開(kāi)源的、擴(kuò)展了PostgreSQL的時(shí)序數(shù)據(jù)庫(kù)擴(kuò)展,本文就給大家詳細(xì)的介紹一下基于PostgreSQL的時(shí)序數(shù)據(jù)庫(kù)TimescaleDB的基本用法和概念,需要的朋友可以參考下
    2023-06-06

最新評(píng)論