Struct Table

Source
pub struct Table<'a> { /* private fields */ }
Expand description

Instance of a ESE database table in a currently open crate::EseDb.

Implementations§

Source§

impl Table<'_>

Source

pub fn name(&self) -> Result<String>

Gets the name of the table.

Examples found in repository?
examples/overview.rs (line 13)
3fn main() {
4    let filename = std::env::args()
5        .nth(1)
6        .expect("specify path to .esedb file");
7    let db = EseDb::open(&filename).unwrap();
8    println!("Database Overview ({}):", filename);
9    for table in db.iter_tables().unwrap() {
10        let table = table.unwrap();
11        println!(
12            "  {} [{:?}]",
13            table.name().unwrap(),
14            table
15                .iter_columns()
16                .unwrap()
17                .map(|c| c.unwrap().name().unwrap())
18                .collect::<Vec<String>>()
19                .join(", "),
20        );
21        for record in table.iter_records().unwrap() {
22            let record = record.unwrap();
23            for i in 0..record.count_values().unwrap() {
24                println!(
25                    "  ├ T={:?} L={}, M={} V={:?}",
26                    table.column(i).unwrap().variant().unwrap(),
27                    record.is_long(i).unwrap(),
28                    record.is_multi(i).unwrap(),
29                    record.value(i).unwrap(),
30                );
31            }
32        }
33    }
34}
Source

pub fn count_columns(&self) -> Result<i32>

Total number of columns in table.

Source

pub fn count_records(&self) -> Result<i32>

Total number of records (rows) in table.

Source

pub fn column(&self, entry: i32) -> Result<Column<'_>>

Load a specific column by entry number. Returned Column is bound to the lifetime of the database table.

Examples found in repository?
examples/overview.rs (line 26)
3fn main() {
4    let filename = std::env::args()
5        .nth(1)
6        .expect("specify path to .esedb file");
7    let db = EseDb::open(&filename).unwrap();
8    println!("Database Overview ({}):", filename);
9    for table in db.iter_tables().unwrap() {
10        let table = table.unwrap();
11        println!(
12            "  {} [{:?}]",
13            table.name().unwrap(),
14            table
15                .iter_columns()
16                .unwrap()
17                .map(|c| c.unwrap().name().unwrap())
18                .collect::<Vec<String>>()
19                .join(", "),
20        );
21        for record in table.iter_records().unwrap() {
22            let record = record.unwrap();
23            for i in 0..record.count_values().unwrap() {
24                println!(
25                    "  ├ T={:?} L={}, M={} V={:?}",
26                    table.column(i).unwrap().variant().unwrap(),
27                    record.is_long(i).unwrap(),
28                    record.is_multi(i).unwrap(),
29                    record.value(i).unwrap(),
30                );
31            }
32        }
33    }
34}
Source

pub fn record(&self, entry: i32) -> Result<Record<'_>>

Load a specific record (row) by entry number. Returned Record is bound to the lifetime of the database table.

Source

pub fn iter_columns(&self) -> Result<impl Iterator<Item = Result<Column<'_>>>>

Create an iterator over all the columns in the table. The [IterEntries] iterator and the returned Columns are bound to the lifetime of the database table.

for column in table.iter_columns()? {
    println!("{}", column?.name()?);
}
Examples found in repository?
examples/overview.rs (line 15)
3fn main() {
4    let filename = std::env::args()
5        .nth(1)
6        .expect("specify path to .esedb file");
7    let db = EseDb::open(&filename).unwrap();
8    println!("Database Overview ({}):", filename);
9    for table in db.iter_tables().unwrap() {
10        let table = table.unwrap();
11        println!(
12            "  {} [{:?}]",
13            table.name().unwrap(),
14            table
15                .iter_columns()
16                .unwrap()
17                .map(|c| c.unwrap().name().unwrap())
18                .collect::<Vec<String>>()
19                .join(", "),
20        );
21        for record in table.iter_records().unwrap() {
22            let record = record.unwrap();
23            for i in 0..record.count_values().unwrap() {
24                println!(
25                    "  ├ T={:?} L={}, M={} V={:?}",
26                    table.column(i).unwrap().variant().unwrap(),
27                    record.is_long(i).unwrap(),
28                    record.is_multi(i).unwrap(),
29                    record.value(i).unwrap(),
30                );
31            }
32        }
33    }
34}
Source

pub fn iter_records(&self) -> Result<impl Iterator<Item = Result<Record<'_>>>>

Create an iterator over all the records (rows) in the table. The [IterEntries] iterator and the returned Records are bound to the lifetime of the database table.

for record in table.iter_records()? {
    let record = record?;
    for value in record.iter_values()? {
        println!("{:?}", value?);
    }
}
Examples found in repository?
examples/fh-catalog-strings.rs (line 10)
3fn main() {
4    let filename = std::env::args()
5        .nth(1)
6        .unwrap_or("Catalog1.edb".to_string());
7    let db = EseDb::open(filename).unwrap();
8    println!("Db load finished!");
9    let string = db.table_by_name("string").unwrap();
10    for rec in string.iter_records().unwrap() {
11        let rec = rec.unwrap();
12        let vals = rec
13            .iter_values()
14            .unwrap()
15            .map(|v| v.unwrap_or_default().to_string())
16            .collect::<Vec<_>>();
17        println!("{}", vals.join("\t"));
18    }
19}
More examples
Hide additional examples
examples/overview.rs (line 21)
3fn main() {
4    let filename = std::env::args()
5        .nth(1)
6        .expect("specify path to .esedb file");
7    let db = EseDb::open(&filename).unwrap();
8    println!("Database Overview ({}):", filename);
9    for table in db.iter_tables().unwrap() {
10        let table = table.unwrap();
11        println!(
12            "  {} [{:?}]",
13            table.name().unwrap(),
14            table
15                .iter_columns()
16                .unwrap()
17                .map(|c| c.unwrap().name().unwrap())
18                .collect::<Vec<String>>()
19                .join(", "),
20        );
21        for record in table.iter_records().unwrap() {
22            let record = record.unwrap();
23            for i in 0..record.count_values().unwrap() {
24                println!(
25                    "  ├ T={:?} L={}, M={} V={:?}",
26                    table.column(i).unwrap().variant().unwrap(),
27                    record.is_long(i).unwrap(),
28                    record.is_multi(i).unwrap(),
29                    record.value(i).unwrap(),
30                );
31            }
32        }
33    }
34}
Source

pub fn close(self)

👎Deprecated

When done reading, call this to free resources the table is using in memory.

Trait Implementations§

Source§

impl Drop for Table<'_>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for Table<'a>

§

impl<'a> RefUnwindSafe for Table<'a>

§

impl<'a> !Send for Table<'a>

§

impl<'a> !Sync for Table<'a>

§

impl<'a> Unpin for Table<'a>

§

impl<'a> UnwindSafe for Table<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.