#![allow(unused_variables, unused_mut)]
use rsfbclient::{prelude::*, FbError};
const SQL_INSERT: &str = "insert into test (col_b, col_c) values (?, ?)";
const SQL_INSERT_NAMED: &str = "insert into test (col_b, col_c) values (:colb, :colc)";
const SQL_INSERT_PURE: &str = "insert into test (col_b, col_c) values (32, 'Leite')";
#[derive(Clone, IntoParams)]
struct ParamTest {
colb: f32,
colc: String,
}
#[derive(Clone, IntoParams)]
struct ParamTest2 {
colb: f32,
colc: String,
}
fn main() -> Result<(), FbError> {
#[cfg(feature = "linking")]
let mut conn = rsfbclient::builder_native()
.with_dyn_link()
.with_remote()
.host("localhost")
.db_name("examples.fdb")
.user("SYSDBA")
.pass("masterkey")
.connect()?;
#[cfg(feature = "dynamic_loading")]
let mut conn = rsfbclient::builder_native()
.with_dyn_load("./fbclient.lib")
.with_remote()
.host("localhost")
.db_name("examples.fdb")
.user("SYSDBA")
.pass("masterkey")
.connect()?;
#[cfg(feature = "pure_rust")]
let mut conn = rsfbclient::builder_pure_rust()
.host("localhost")
.db_name("examples.fdb")
.user("SYSDBA")
.pass("masterkey")
.connect()?;
let p1 = ParamTest {
colb: 150.0,
colc: "Café".to_string(),
};
let p2 = ParamTest {
colb: 132.0,
colc: "Arroz".to_string(),
};
let p3 = ParamTest2 {
colb: 150.0,
colc: "Feijão".to_string(),
};
conn.with_transaction(|tr| {
tr.execute(SQL_INSERT, (94, "Banana"))?; tr.execute(SQL_INSERT_NAMED, p1.clone())?; tr.execute(SQL_INSERT_NAMED, p3.clone())?;
tr.execute_immediate(SQL_INSERT_PURE)?;
{
let mut stmt = tr.prepare(SQL_INSERT, false)?;
stmt.execute((-39, "test"))?;
stmt.execute((12, "test 2"))?;
}
{
let mut stmt = tr.prepare(SQL_INSERT_NAMED, true)?;
stmt.execute(p1.clone())?;
stmt.execute(p2.clone())?;
stmt.execute(p3.clone())?;
}
Ok(())
})?;
conn.close()?;
Ok(())
}