risingwave_frontend/catalog/system_catalog/pg_catalog/
pg_indexes.rs1use risingwave_common::types::Fields;
16use risingwave_frontend_macro::system_catalog;
17
18#[system_catalog(
21 view,
22 "pg_catalog.pg_indexes",
23 "SELECT s.name AS schemaname,
24 t.name AS tablename,
25 i.name AS indexname,
26 NULL AS tablespace,
27 i.definition AS indexdef
28 FROM rw_catalog.rw_indexes i
29 JOIN rw_catalog.rw_tables t ON i.primary_table_id = t.id
30 JOIN rw_catalog.rw_schemas s ON i.schema_id = s.id
31 UNION ALL
32 SELECT s.name AS schemaname,
33 t.name AS tablename,
34 i.name AS indexname,
35 NULL AS tablespace,
36 i.definition AS indexdef
37 FROM rw_catalog.rw_indexes i
38 JOIN rw_catalog.rw_materialized_views t ON i.primary_table_id = t.id
39 JOIN rw_catalog.rw_schemas s ON i.schema_id = s.id
40 UNION ALL
41 SELECT s.name AS schemaname,
42 t.name AS tablename,
43 concat(t.name, '_pkey') AS indexname,
44 NULL AS tablespace,
45 '' AS indexdef
46 FROM rw_catalog.rw_tables t
47 JOIN rw_catalog.rw_schemas s ON t.schema_id = s.id
48 WHERE t.id IN (
49 SELECT DISTINCT relation_id
50 FROM rw_catalog.rw_columns
51 WHERE is_primary_key = true AND is_hidden = false
52 )
53 "
54)]
55#[derive(Fields)]
56struct PgIndexes {
57 schemaname: String,
58 tablename: String,
59 indexname: String,
60 tablespace: String,
61 indexdef: String,
62}