use fdb_driver::{ConnectConfig, Connection, Result, WireCrypt};
fn main() -> Result<()> {
let cfg = ConnectConfig::new()
.host(std::env::var("FB_HOST").unwrap_or_else(|_| "127.0.0.1".into()))
.port(
std::env::var("FB_PORT")
.ok()
.and_then(|p| p.parse().ok())
.unwrap_or(3555),
)
.database(std::env::var("FB_DB").unwrap_or_else(|_| "employee".into()))
.user(std::env::var("FB_USER").unwrap_or_else(|_| "SYSDBA".into()))
.password(std::env::var("FB_PASSWORD").expect("set FB_PASSWORD"))
.wire_crypt(WireCrypt::Enabled);
let mut conn = Connection::connect(&cfg)?;
println!("conectado: protocolo v{}", conn.protocol_version());
let tx = conn.begin()?;
let sql = "SELECT emp_no, first_name FROM employee WHERE emp_no = 2";
let stmt = conn.prepare(&tx, sql)?;
println!(
"\nstmt_type={} colunas={}",
stmt.stmt_type(),
stmt.columns().len()
);
for c in stmt.columns() {
println!(
" [{}] name={:?} field={:?} relation={:?} alias={:?} owner={:?} type={} sub={} scale={} len={}",
c.index,
c.name(),
c.field,
c.relation,
c.alias,
c.owner,
c.sql_type,
c.sub_type,
c.scale,
c.length
);
}
stmt.drop_statement(&mut conn)?;
tx.commit(&mut conn)?;
conn.close()?;
Ok(())
}