1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
use std::{borrow::BorrowMut, intrinsics::transmute};
use widestring::U16Str;
use crate::{
handles::{Statement, StatementImpl},
parameter::Blob,
CursorImpl, Error, ParameterCollection,
};
pub fn execute_with_parameters<'o, S>(
lazy_statement: impl FnOnce() -> Result<S, Error>,
query: Option<&U16Str>,
params: impl ParameterCollection,
) -> Result<Option<CursorImpl<'o, S>>, Error>
where
S: BorrowMut<StatementImpl<'o>>,
{
let parameter_set_size = params.parameter_set_size();
if parameter_set_size == 0 {
return Ok(None);
}
let mut statement = lazy_statement()?;
let stmt = statement.borrow_mut();
stmt.reset_parameters()?;
let need_data = unsafe {
stmt.set_paramset_size(parameter_set_size)?;
params.bind_parameters_to(stmt)?;
if let Some(sql) = query {
stmt.exec_direct(sql)?
} else {
stmt.execute()?
}
};
if need_data {
while let Some(blob_ptr) = stmt.param_data()? {
let blob_ref = unsafe {
let blob_ptr: *mut &mut dyn Blob = transmute(blob_ptr);
&mut *blob_ptr
};
while let Some(batch) = blob_ref.next_batch().map_err(Error::FailedReadingInput)? {
stmt.put_binary_batch(batch)?;
}
}
}
if stmt.num_result_cols()? == 0 {
Ok(None)
} else {
Ok(Some(CursorImpl::new(statement)))
}
}
pub fn columns<'o, S>(
mut statement: S,
catalog_name: &U16Str,
schema_name: &U16Str,
table_name: &U16Str,
column_name: &U16Str,
) -> Result<CursorImpl<'o, S>, Error>
where
S: BorrowMut<StatementImpl<'o>>,
{
let stmt = statement.borrow_mut();
stmt.columns(catalog_name, schema_name, table_name, column_name)?;
debug_assert_ne!(stmt.num_result_cols().unwrap(), 0);
Ok(CursorImpl::new(statement))
}