pg_extras/queries/
indexes.rs

1use crate::{queries::shared::Query, PgStatsVersion};
2use sqlx::{postgres::PgRow, Row};
3
4#[derive(Debug, Clone, serde::Serialize)]
5pub struct Indexes {
6    pub schemaname: String,
7    pub indexname: String,
8    pub tablename: String,
9    pub columns: String,
10}
11
12impl Query for Indexes {
13    fn new(row: &PgRow) -> Self {
14        Self {
15            schemaname: row.try_get("schemaname").unwrap_or_default(),
16            indexname: row.try_get("indexname").unwrap_or_default(),
17            tablename: row.try_get("tablename").unwrap_or_default(),
18            columns: row.try_get("columns").unwrap_or_default(),
19        }
20    }
21
22    fn to_row(&self) -> prettytable::Row {
23        row![
24            self.schemaname,
25            self.indexname,
26            self.tablename,
27            self.columns
28        ]
29    }
30
31    fn headers() -> prettytable::Row {
32        row!["schemaname", "indexname", "tablename", "columns"]
33    }
34
35    fn read_file(_pg_statement_version: Option<PgStatsVersion>) -> String {
36        include_str!("../sql/indexes.sql").to_string()
37    }
38}