PostgreSQL: एक तालिका का निर्माण दिनांक


13

मैंने हाल ही में एक परियोजना पूरी की है, जिसके दौरान कई डीबी टेबल बनाए गए थे।

इनमें से अधिकांश तालिकाओं में अस्थायी कचरा होता है, और मैं इन सभी तालिकाओं को सूचीबद्ध करने का एक सरल तरीका खोज रहा हूं।

क्या सभी डीबी तालिकाओं को उनकी निर्माण तिथि के अनुसार क्रमबद्ध करने का एक तरीका है?

जवाबों:



5

हाँ यह संभव है - सीमाओं के साथ।

देख

/programming/18849756/automatically-drop-tables-and-indexes-older-than-90-days/18852752#18852752

अधिक जानकारी के लिए

WITH CTE AS
(
    SELECT 
        table_name 

        ,
        (
            SELECT 
                MAX(pg_ls_dir::int)::text 
            FROM pg_ls_dir('./base') 
            WHERE pg_ls_dir <> 'pgsql_tmp' 
            AND  pg_ls_dir::int  <= (SELECT relfilenode FROM pg_class WHERE relname ILIKE table_name)
        ) as folder 


        ,(SELECT relfilenode FROM pg_class WHERE relname ILIKE table_name) filenode

    FROM information_schema.tables
    WHERE table_type = 'BASE TABLE'
    AND table_schema = 'public'
)

SELECT 
    table_name 
    ,(
        SELECT creation 
        FROM pg_stat_file(
            './base/' || folder || '/' || filenode 
        )
    ) as creation_time
FROM CTE;

3

नहीं, यह संभव नहीं है जहाँ तक मुझे पता है।

यह मान सिस्टम तालिकाओं में से किसी में संग्रहीत नहीं है (हालांकि अच्छा होगा)।


1

यह प्रश्न

select pslo.stasubtype, pc.relname, pslo.statime
from pg_stat_last_operation pslo
join pg_class pc on(pc.relfilenode = pslo.objid)
and pslo.staactionname = 'CREATE'
order by pslo.statime desc 

निश्चित रूप से मदद मिलेगी।

NB: यह केवल ग्रीनप्लम पर काम करता है।


0

तालिका निर्माण समय प्राप्त करना संभव नहीं है, लेकिन आप वास्तव में उन तालिकाओं की सूची प्राप्त कर सकते हैं जो हाल ही में बनाई गई हैं यदि आप अपने डेटाबेस को नियमित रूप से वैक्यूम करते हैं। आप इस क्वेरी का उपयोग कर सकते हैं: pg_stat_user_tables से * सेलेक्ट करें जहाँ last_vacuum> अभी () - अंतराल '3 दिन'; आप अपनी आवश्यकता के अनुसार अंतराल को बदल सकते हैं।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.