pg_extras/queries/
indexes.rs1use 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}