Skip to main content

Statement

Struct Statement 

Source
pub struct Statement { /* private fields */ }
Expand description

Uma instrução preparada vinculada ao handle de banco de dados de uma Connection.

Implementations§

Source§

impl Statement

Source

pub fn handle(&self) -> i32

O handle da instrução no lado do servidor.

Source

pub fn stmt_type(&self) -> i32

O tipo da instrução (stmt_type::*, ex.: SELECT, INSERT).

Examples found in repository?
examples/dump.rs (line 33)
11fn main() -> Result<()> {
12    let cfg = ConnectConfig::new()
13        .host(std::env::var("FB_HOST").unwrap_or_else(|_| "127.0.0.1".into()))
14        .port(
15            std::env::var("FB_PORT")
16                .ok()
17                .and_then(|p| p.parse().ok())
18                .unwrap_or(3555),
19        )
20        .database(std::env::var("FB_DB").unwrap_or_else(|_| "employee".into()))
21        .user(std::env::var("FB_USER").unwrap_or_else(|_| "SYSDBA".into()))
22        .password(std::env::var("FB_PASSWORD").expect("set FB_PASSWORD"))
23        .wire_crypt(WireCrypt::Enabled);
24
25    let mut conn = Connection::connect(&cfg)?;
26    println!("conectado: protocolo v{}", conn.protocol_version());
27    let tx = conn.begin()?;
28
29    let sql = "SELECT emp_no, first_name FROM employee WHERE emp_no = 2";
30    let stmt = conn.prepare(&tx, sql)?;
31    println!(
32        "\nstmt_type={} colunas={}",
33        stmt.stmt_type(),
34        stmt.columns().len()
35    );
36    for c in stmt.columns() {
37        println!(
38            "  [{}] name={:?} field={:?} relation={:?} alias={:?} owner={:?} type={} sub={} scale={} len={}",
39            c.index,
40            c.name(),
41            c.field,
42            c.relation,
43            c.alias,
44            c.owner,
45            c.sql_type,
46            c.sub_type,
47            c.scale,
48            c.length
49        );
50    }
51
52    stmt.drop_statement(&mut conn)?;
53    tx.commit(&mut conn)?;
54    conn.close()?;
55    Ok(())
56}
Source

pub fn is_select(&self) -> bool

Verdadeiro para instruções que produzem um cursor de linhas.

Source

pub fn set_scrollable(&mut self, yes: bool)

Pede que o próximo Self::execute abra um cursor rolável, habilitando Self::fetch_scroll e seus atalhos (fetch_prior, fetch_absolute, …). Deve ser chamado antes do execute; o servidor precisa suportar cursores roláveis (FB5+ / protocolo ≥ 17 — ver Connection::supports_fetch_scroll).

Source

pub fn is_scrollable(&self) -> bool

Se este statement foi marcado para abrir um cursor rolável.

Source

pub fn set_fetch_size(&mut self, n: i32)

Define quantas linhas pedir por op_fetch (prefetch). Valores maiores reduzem o número de idas ao servidor em SELECTs grandes, ao custo de mais memória de buffer por lote; valores menores reduzem a latência da primeira linha. O padrão é 200. n é fixado em pelo menos 1.

Source

pub fn fetch_size(&self) -> i32

O tamanho de prefetch atual (ver Self::set_fetch_size).

Source

pub fn columns(&self) -> &[ColumnMeta]

Metadados das colunas de saída (vazio para instruções que não são SELECT).

Examples found in repository?
examples/dump.rs (line 34)
11fn main() -> Result<()> {
12    let cfg = ConnectConfig::new()
13        .host(std::env::var("FB_HOST").unwrap_or_else(|_| "127.0.0.1".into()))
14        .port(
15            std::env::var("FB_PORT")
16                .ok()
17                .and_then(|p| p.parse().ok())
18                .unwrap_or(3555),
19        )
20        .database(std::env::var("FB_DB").unwrap_or_else(|_| "employee".into()))
21        .user(std::env::var("FB_USER").unwrap_or_else(|_| "SYSDBA".into()))
22        .password(std::env::var("FB_PASSWORD").expect("set FB_PASSWORD"))
23        .wire_crypt(WireCrypt::Enabled);
24
25    let mut conn = Connection::connect(&cfg)?;
26    println!("conectado: protocolo v{}", conn.protocol_version());
27    let tx = conn.begin()?;
28
29    let sql = "SELECT emp_no, first_name FROM employee WHERE emp_no = 2";
30    let stmt = conn.prepare(&tx, sql)?;
31    println!(
32        "\nstmt_type={} colunas={}",
33        stmt.stmt_type(),
34        stmt.columns().len()
35    );
36    for c in stmt.columns() {
37        println!(
38            "  [{}] name={:?} field={:?} relation={:?} alias={:?} owner={:?} type={} sub={} scale={} len={}",
39            c.index,
40            c.name(),
41            c.field,
42            c.relation,
43            c.alias,
44            c.owner,
45            c.sql_type,
46            c.sub_type,
47            c.scale,
48            c.length
49        );
50    }
51
52    stmt.drop_statement(&mut conn)?;
53    tx.commit(&mut conn)?;
54    conn.close()?;
55    Ok(())
56}
Source

pub fn params(&self) -> &[ColumnMeta]

Metadados dos parâmetros de entrada.

Source

pub fn execute( &mut self, conn: &mut Connection, tx: &Transaction, params: &[Value], ) -> Result<()>

Executa a instrução. Para um SELECT isto abre um cursor; prossiga com Self::fetch / Self::fetch_all. Para DML o servidor responde com um op_response simples.

Source

pub fn fetch(&mut self, conn: &mut Connection) -> Result<Option<Vec<Value>>>

Busca a próxima linha, ou None no fim do cursor. Retorna None para uma instrução que não tem cursor aberto (que não é SELECT, ou já esgotada).

Source

pub fn fetch_all(&mut self, conn: &mut Connection) -> Result<Vec<Vec<Value>>>

Esvazia o cursor para um vetor de linhas.

Source

pub fn rows<'a>(&'a mut self, conn: &'a mut Connection) -> RowStream<'a>

Cria um stream síncrono sobre as linhas do cursor (ver RowStream), empacotando a conexão para não precisar repassá-la a cada linha. As linhas chegam sob demanda (em lotes de Self::fetch_size), sem materializar tudo na memória como Self::fetch_all.

let mut rows = stmt.rows(&mut conn);
while let Some(row) = rows.try_next()? {
    println!("{row:?}");
}
Source

pub fn fetch_scroll( &mut self, conn: &mut Connection, direction: i32, offset: i32, ) -> Result<Option<Vec<Value>>>

Reposiciona o cursor (rolável) e retorna a única linha naquela posição, ou None se ela cai fora do conjunto de resultados. Envia op_fetch_scroll (FB5); o cursor precisa ter sido aberto com Self::set_scrollable.

direction é uma das constantes scroll; offset é a posição absoluta (1-based) para scroll::ABSOLUTE, o deslocamento com sinal para scroll::RELATIVE, e ignorado (use 0) nas demais direções.

Source

pub fn fetch_next( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>

Próxima linha (rolável). Equivale a Self::fetch num cursor rolável.

Source

pub fn fetch_prior( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>

Linha anterior.

Source

pub fn fetch_first( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>

Primeira linha do conjunto de resultados.

Source

pub fn fetch_last( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>

Última linha do conjunto de resultados.

Source

pub fn fetch_absolute( &mut self, conn: &mut Connection, pos: i32, ) -> Result<Option<Vec<Value>>>

Linha na posição absoluta pos (1-based; negativa conta a partir do fim).

Source

pub fn fetch_relative( &mut self, conn: &mut Connection, offset: i32, ) -> Result<Option<Vec<Value>>>

Linha offset posições à frente (positivo) ou atrás (negativo) da atual.

Source

pub fn rows_affected(&self, conn: &mut Connection) -> Result<RowsAffected>

Quantas linhas a última execução afetou, via op_info_sql com isc_info_sql_records. Útil após um INSERT/UPDATE/DELETE — use RowsAffected::total_modified para o total.

Source

pub fn close(&mut self, conn: &mut Connection) -> Result<()>

Fecha o cursor aberto (op_free_statement com DSQL_close) sem liberar a instrução preparada, para que possa ser reexecutada.

Source

pub fn drop_statement(self, conn: &mut Connection) -> Result<()>

Libera a instrução no servidor (op_free_statement com DSQL_drop), consumindo o handle.

Examples found in repository?
examples/dump.rs (line 52)
11fn main() -> Result<()> {
12    let cfg = ConnectConfig::new()
13        .host(std::env::var("FB_HOST").unwrap_or_else(|_| "127.0.0.1".into()))
14        .port(
15            std::env::var("FB_PORT")
16                .ok()
17                .and_then(|p| p.parse().ok())
18                .unwrap_or(3555),
19        )
20        .database(std::env::var("FB_DB").unwrap_or_else(|_| "employee".into()))
21        .user(std::env::var("FB_USER").unwrap_or_else(|_| "SYSDBA".into()))
22        .password(std::env::var("FB_PASSWORD").expect("set FB_PASSWORD"))
23        .wire_crypt(WireCrypt::Enabled);
24
25    let mut conn = Connection::connect(&cfg)?;
26    println!("conectado: protocolo v{}", conn.protocol_version());
27    let tx = conn.begin()?;
28
29    let sql = "SELECT emp_no, first_name FROM employee WHERE emp_no = 2";
30    let stmt = conn.prepare(&tx, sql)?;
31    println!(
32        "\nstmt_type={} colunas={}",
33        stmt.stmt_type(),
34        stmt.columns().len()
35    );
36    for c in stmt.columns() {
37        println!(
38            "  [{}] name={:?} field={:?} relation={:?} alias={:?} owner={:?} type={} sub={} scale={} len={}",
39            c.index,
40            c.name(),
41            c.field,
42            c.relation,
43            c.alias,
44            c.owner,
45            c.sql_type,
46            c.sub_type,
47            c.scale,
48            c.length
49        );
50    }
51
52    stmt.drop_statement(&mut conn)?;
53    tx.commit(&mut conn)?;
54    conn.close()?;
55    Ok(())
56}

Trait Implementations§

Source§

impl Debug for Statement

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Drop for Statement

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. Read more

Auto Trait Implementations§

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

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> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V