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
use super::*;
impl QueryBuilder for SqliteQueryBuilder {
fn char_length_function(&self) -> &str {
"LENGTH"
}
fn prepare_select_lock(
&self,
_select_lock: &LockType,
_sql: &mut SqlWriter,
_collector: &mut dyn FnMut(Value),
) {
}
fn prepare_order_expr(
&self,
order_expr: &OrderExpr,
sql: &mut SqlWriter,
collector: &mut dyn FnMut(Value),
) {
if !matches!(order_expr.order, Order::Field(_)) {
self.prepare_simple_expr(&order_expr.expr, sql, collector);
}
write!(sql, " ").unwrap();
self.prepare_order(order_expr, sql, collector);
match order_expr.nulls {
None => (),
Some(NullOrdering::Last) => write!(sql, " NULLS LAST").unwrap(),
Some(NullOrdering::First) => write!(sql, " NULLS FIRST").unwrap(),
}
}
fn prepare_query_statement(
&self,
query: &SubQueryStatement,
sql: &mut SqlWriter,
collector: &mut dyn FnMut(Value),
) {
query.prepare_statement(self, sql, collector);
}
fn prepare_with_clause_recursive_options(
&self,
_: &WithClause,
_: &mut SqlWriter,
_: &mut dyn FnMut(Value),
) {
}
}