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
impl Statement
Sourcepub fn set_scrollable(&mut self, yes: bool)
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).
Sourcepub fn is_scrollable(&self) -> bool
pub fn is_scrollable(&self) -> bool
Se este statement foi marcado para abrir um cursor rolável.
Sourcepub fn set_fetch_size(&mut self, n: i32)
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.
Sourcepub fn fetch_size(&self) -> i32
pub fn fetch_size(&self) -> i32
O tamanho de prefetch atual (ver Self::set_fetch_size).
Sourcepub fn columns(&self) -> &[ColumnMeta]
pub fn columns(&self) -> &[ColumnMeta]
Metadados das colunas de saída (vazio para instruções que não são SELECT).
Sourcepub fn params(&self) -> &[ColumnMeta]
pub fn params(&self) -> &[ColumnMeta]
Metadados dos parâmetros de entrada.
Sourcepub fn execute(
&mut self,
conn: &mut Connection,
tx: &Transaction,
params: &[Value],
) -> Result<()>
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.
Sourcepub fn fetch(&mut self, conn: &mut Connection) -> Result<Option<Vec<Value>>>
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).
Sourcepub fn fetch_all(&mut self, conn: &mut Connection) -> Result<Vec<Vec<Value>>>
pub fn fetch_all(&mut self, conn: &mut Connection) -> Result<Vec<Vec<Value>>>
Esvazia o cursor para um vetor de linhas.
Sourcepub fn rows<'a>(&'a mut self, conn: &'a mut Connection) -> RowStream<'a>
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:?}");
}Sourcepub fn fetch_scroll(
&mut self,
conn: &mut Connection,
direction: i32,
offset: i32,
) -> Result<Option<Vec<Value>>>
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.
Sourcepub fn fetch_next(
&mut self,
conn: &mut Connection,
) -> Result<Option<Vec<Value>>>
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.
Sourcepub fn fetch_prior(
&mut self,
conn: &mut Connection,
) -> Result<Option<Vec<Value>>>
pub fn fetch_prior( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>
Linha anterior.
Sourcepub fn fetch_first(
&mut self,
conn: &mut Connection,
) -> Result<Option<Vec<Value>>>
pub fn fetch_first( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>
Primeira linha do conjunto de resultados.
Sourcepub fn fetch_last(
&mut self,
conn: &mut Connection,
) -> Result<Option<Vec<Value>>>
pub fn fetch_last( &mut self, conn: &mut Connection, ) -> Result<Option<Vec<Value>>>
Última linha do conjunto de resultados.
Sourcepub fn fetch_absolute(
&mut self,
conn: &mut Connection,
pos: i32,
) -> Result<Option<Vec<Value>>>
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).
Sourcepub fn fetch_relative(
&mut self,
conn: &mut Connection,
offset: i32,
) -> Result<Option<Vec<Value>>>
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.
Sourcepub fn rows_affected(&self, conn: &mut Connection) -> Result<RowsAffected>
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.
Sourcepub fn close(&mut self, conn: &mut Connection) -> Result<()>
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.
Sourcepub fn drop_statement(self, conn: &mut Connection) -> Result<()>
pub fn drop_statement(self, conn: &mut Connection) -> Result<()>
Libera a instrução no servidor (op_free_statement com DSQL_drop),
consumindo o handle.