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 stmt_type(&self) -> i32
pub fn stmt_type(&self) -> i32
O tipo da instrução (stmt_type::*, ex.: SELECT, INSERT).
Examples found in repository?
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}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).
Examples found in repository?
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}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.
Examples found in repository?
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}