Mengesahkan Kewujudan Jadual Dalam Skema PostgreSQL Tertentu
Mengesahkan kehadiran jadual dengan cekap dalam skema PostgreSQL yang ditetapkan adalah penting untuk pengurusan pangkalan data. Panduan ini menggariskan beberapa kaedah untuk mencapai matlamat ini, memfokuskan pada skema sasaran semata-mata.
Memanfaatkan Katalog Sistem
Katalog sistem PostgreSQL menawarkan inventori lengkap objek pangkalan data. Untuk menyemak kewujudan jadual dalam skema tertentu, tanya katalog pg_class
, disertai dengan pg_namespace
untuk penapisan skema:
<code class="language-sql">SELECT EXISTS ( SELECT FROM pg_catalog.pg_class c JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace WHERE n.nspname = 'schema_name' AND c.relname = 'table_name' AND c.relkind = 'r' -- limits results to tables );</code>
Pendekatan Diperkemas
Menghantar nama jadual ke jenis regclass
menawarkan alternatif yang ringkas. Pelakon yang berjaya mengembalikan ID Objek (OID); kegagalan menunjukkan ketiadaan jadual:
<code class="language-sql">SELECT 'schema_name.table_name'::regclass;</code>
Mengurus Pengecam Petikan Dua Kali
Untuk nama jadual menggunakan petikan berganda (membenarkan aksara khas), sertakan petikan dalam pertanyaan anda:
<code class="language-sql">SELECT '"schema_name"."table_name"'::regclass;</code>
Menggunakan Fungsi to_regclass
(PostgreSQL 9.4 dan lebih baru)
PostgreSQL 9.4 menyediakan fungsi to_regclass
, memudahkan proses. Ia mengembalikan NULL
jika jadual tidak ditemui, menghapuskan pengendalian pengecualian:
<code class="language-sql">SELECT to_regclass('schema_name.table_name');</code>
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Semak Kewujudan Jadual dengan Cekap dalam Skema PostgreSQL Tertentu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!