Commit d85ace0
authored
feat: filter & service corrections (#431)
## Summary
Closes a cluster of filter-correctness issues filed 2026-04-26 and adds the
first-party service base classes that downstream consumers have been
re-implementing.
- Closes #424 — `StatementFilter`s now emit qualified columns; dotted
`field_name="users.name"` works without `AmbiguousColumnError` on joined
SELECTs and the count-query path.
- Closes #425 — `SearchFilter` / `NotInSearchFilter` now raise `TypeError`
for unsupported `field_name` types instead of silently dropping the WHERE
clause, and accept `exp.Expression` (e.g. `LOWER(name)`) as a sort/search
key — finishing the type widening started for #427.
- Closes #426 — `QueryBuilder.order_by(sql.raw("COL DESC"))` correctly
emits `ORDER BY ... DESC` instead of treating `DESC` as a column alias.
- Closes #427 — `OrderByFilter.field_name` (and `SearchFilter.field_name`)
accept `exp.Expression` for computed-column ordering/search; the wire
surface (`?orderBy=`) stays `str`-only.
- Closes #428 — exposes `SearchFilter.like_pattern` and adds
`SearchFilter.escape_like_value()` so consumers bypassing the standard
filter pipeline can opt into safe `%`/`_` escaping.
- Closes #429 — adds first-party `SQLSpecAsyncService` /
`SQLSpecSyncService` in `sqlspec/service.py`
(`paginate`, `get_or_404`, `exists`, `begin`/`commit`/`rollback`,
`begin_transaction`) and re-exports them from every framework
extension package. Flask re-exports the sync class only.1 parent 258cb64 commit d85ace0
22 files changed
Lines changed: 1302 additions & 187 deletions
File tree
- docs
- recipes
- usage
- sqlspec
- builder
- core
- driver
- extensions
- fastapi
- flask
- litestar
- sanic
- starlette
- utils/serializers
- tests
- integration/extensions/litestar
- unit
- builder
- core
- extensions
- test_litestar
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
39 | 39 | | |
40 | 40 | | |
41 | 41 | | |
42 | | - | |
| 42 | + | |
43 | 43 | | |
44 | 44 | | |
45 | 45 | | |
| |||
88 | 88 | | |
89 | 89 | | |
90 | 90 | | |
91 | | - | |
| 91 | + | |
92 | 92 | | |
93 | 93 | | |
94 | 94 | | |
| |||
160 | 160 | | |
161 | 161 | | |
162 | 162 | | |
163 | | - | |
| 163 | + | |
164 | 164 | | |
165 | 165 | | |
166 | 166 | | |
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
212 | | - | |
| 212 | + | |
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
| |||
294 | 294 | | |
295 | 295 | | |
296 | 296 | | |
297 | | - | |
| 297 | + | |
298 | 298 | | |
299 | 299 | | |
300 | 300 | | |
| |||
338 | 338 | | |
339 | 339 | | |
340 | 340 | | |
341 | | - | |
| 341 | + | |
342 | 342 | | |
343 | 343 | | |
344 | 344 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
21 | 20 | | |
22 | 21 | | |
23 | 22 | | |
24 | 23 | | |
25 | 24 | | |
26 | 25 | | |
27 | 26 | | |
28 | | - | |
| 27 | + | |
29 | 28 | | |
30 | 29 | | |
31 | 30 | | |
32 | 31 | | |
33 | 32 | | |
34 | 33 | | |
35 | 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 | + | |
36 | 71 | | |
| 72 | + | |
37 | 73 | | |
38 | 74 | | |
39 | 75 | | |
| |||
76 | 112 | | |
77 | 113 | | |
78 | 114 | | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
79 | 136 | | |
80 | 137 | | |
81 | 138 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
27 | | - | |
| 27 | + | |
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| |||
264 | 264 | | |
265 | 265 | | |
266 | 266 | | |
267 | | - | |
| 267 | + | |
268 | 268 | | |
269 | 269 | | |
270 | 270 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
425 | 425 | | |
426 | 426 | | |
427 | 427 | | |
428 | | - | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
429 | 435 | | |
430 | 436 | | |
431 | 437 | | |
| |||
0 commit comments