जवाबों:
Stackoverflow पर यह मिला: /programming/2577168/postgresql-table-creation-time
हाँ यह संभव है - सीमाओं के साथ।
देख
/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;
नहीं, यह संभव नहीं है जहाँ तक मुझे पता है।
यह मान सिस्टम तालिकाओं में से किसी में संग्रहीत नहीं है (हालांकि अच्छा होगा)।
यह प्रश्न
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: यह केवल ग्रीनप्लम पर काम करता है।
तालिका निर्माण समय प्राप्त करना संभव नहीं है, लेकिन आप वास्तव में उन तालिकाओं की सूची प्राप्त कर सकते हैं जो हाल ही में बनाई गई हैं यदि आप अपने डेटाबेस को नियमित रूप से वैक्यूम करते हैं। आप इस क्वेरी का उपयोग कर सकते हैं: pg_stat_user_tables से * सेलेक्ट करें जहाँ last_vacuum> अभी () - अंतराल '3 दिन'; आप अपनी आवश्यकता के अनुसार अंतराल को बदल सकते हैं।