@xata.io/client 0.16.1 → 0.16.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +14 -0
- package/README.md +2 -0
- package/Usage.md +27 -6
- package/dist/index.cjs +285 -180
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +44 -8
- package/dist/index.mjs +279 -181
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
@@ -1,5 +1,19 @@
|
|
1
1
|
# @xata.io/client
|
2
2
|
|
3
|
+
## 0.16.2
|
4
|
+
|
5
|
+
### Patch Changes
|
6
|
+
|
7
|
+
- [#541](https://github.com/xataio/client-ts/pull/541) [`c74467c`](https://github.com/xataio/client-ts/commit/c74467caeff4e3d60d0981a173b462e970c6c1fc) Thanks [@SferaDev](https://github.com/SferaDev)! - Add tracing with open telemetry
|
8
|
+
|
9
|
+
* [#551](https://github.com/xataio/client-ts/pull/551) [`ee72bfe`](https://github.com/xataio/client-ts/commit/ee72bfef34765374ec66c7edaa6b5508c3f8e8dc) Thanks [@SferaDev](https://github.com/SferaDev)! - Fix filter operators and dates
|
10
|
+
|
11
|
+
- [#552](https://github.com/xataio/client-ts/pull/552) [`e88effa`](https://github.com/xataio/client-ts/commit/e88effa00f8c2c0e24ec8cd60fb21859ac236191) Thanks [@SferaDev](https://github.com/SferaDev)! - Update error message for required settings
|
12
|
+
|
13
|
+
* [#551](https://github.com/xataio/client-ts/pull/551) [`33293b3`](https://github.com/xataio/client-ts/commit/33293b3509d984bb9b1af457c96260d43f398efe) Thanks [@SferaDev](https://github.com/SferaDev)! - Add aliases for some operators
|
14
|
+
|
15
|
+
- [#534](https://github.com/xataio/client-ts/pull/534) [`efc09b4`](https://github.com/xataio/client-ts/commit/efc09b420a25253b428662c2eec40ff3bc36ce79) Thanks [@SferaDev](https://github.com/SferaDev)! - Make sort direction optional
|
16
|
+
|
3
17
|
## 0.16.1
|
4
18
|
|
5
19
|
### Patch Changes
|
package/README.md
CHANGED
@@ -158,6 +158,8 @@ const page = await xata.db.users.sort('full_name', 'asc').getPaginated();
|
|
158
158
|
|
159
159
|
Query operations (`select()`, `filter()`, `sort()`) return a `Query` object. These objects are immutable. You can add additional constraints, `sort`, etc. by calling their methods, and a new query will be returned. In order to finally make a query to the database you'll invoke `getPaginated()`, `getMany()`, `getAll()`, or `getFirst()`.
|
160
160
|
|
161
|
+
To learn the differences between these methods, see the [reference](https://docs.xata.io/sdk/reference#query).
|
162
|
+
|
161
163
|
```ts
|
162
164
|
// Operators that combine multiple conditions can be deconstructed
|
163
165
|
const { filter, any, all, not, sort } = xata.db.users;
|
package/Usage.md
CHANGED
@@ -38,8 +38,29 @@ To get a collection of records, you can use the `Query` object. It provides the
|
|
38
38
|
|
39
39
|
- `getFirst()`: returns the first record in the query results.
|
40
40
|
- `getPaginated()`: returns a page of records in the query results.
|
41
|
-
- `getAll()`: returns all the records in the query results.
|
42
|
-
- `getMany()`: returns an array of
|
41
|
+
- `getAll()`: returns all the records in the query results by making multiple requests to iterate over all the pages which exist. If the query is not filtered and the table is a large dataset, this operation can affect the performance.
|
42
|
+
- `getMany()`: returns an array with a subset of the first results in the query. The default [pagination](#page) size (20) is used and can be customised by passing a different `{ pagination: { size: number } }` in its options. To learn more about default values, see [helper variables](#helper-variables).
|
43
|
+
|
44
|
+
All these methods allow customising its filters, column selection, column ordering, pagination or cache TTL. For example:
|
45
|
+
|
46
|
+
```ts
|
47
|
+
// First item sorting by name
|
48
|
+
const user = await xata.db.users.getFirst({ sort: 'name' });
|
49
|
+
|
50
|
+
// Get first 50 items but ignore the first one
|
51
|
+
const users = await xata.db.users.getMany({ pagination: { size: 50, offset: 1 } });
|
52
|
+
|
53
|
+
// Get page of 100 items where name contains "foo"
|
54
|
+
const page = await xata.db.users.getPaginated({ filter: { name: { $contains: 'foo' } }, pagination: { size: 100 } });
|
55
|
+
|
56
|
+
// Get all admin users and cache the result for 5 minutes
|
57
|
+
const user = await xata.db.users.filter('role', 'admin').getAll({ cache: 5 * 60 * 1000 });
|
58
|
+
|
59
|
+
// Overwrite values set in a query
|
60
|
+
const query = xata.db.users.filter('role', 'admin').select(['name']);
|
61
|
+
const adminUsers = await query.getAll();
|
62
|
+
const firstAdminUserWithEmail = await query.getFirst({ columns: ['name', 'email'] });
|
63
|
+
```
|
43
64
|
|
44
65
|
Since the [`Repository`](#repository) class implements the `Query` interface, you can use it to query and paginate the records in the table too.
|
45
66
|
|
@@ -375,10 +396,10 @@ for await (const users of xata.db.users.getIterator({ batchSize: 50 })) {
|
|
375
396
|
|
376
397
|
We expose some helper variables of the API limits when paginating:
|
377
398
|
|
378
|
-
- `PAGINATION_MAX_SIZE`: Maximum page size.
|
379
|
-
- `PAGINATION_DEFAULT_SIZE`: Default page size.
|
380
|
-
- `PAGINATION_MAX_OFFSET`: Maximum offset.
|
381
|
-
- `PAGINATION_DEFAULT_OFFSET`: Default offset.
|
399
|
+
- `PAGINATION_MAX_SIZE`: Maximum page size (200).
|
400
|
+
- `PAGINATION_DEFAULT_SIZE`: Default page size (20).
|
401
|
+
- `PAGINATION_MAX_OFFSET`: Maximum offset (800).
|
402
|
+
- `PAGINATION_DEFAULT_OFFSET`: Default offset (0).
|
382
403
|
|
383
404
|
You can use these variables if you implement your own pagination mechanism, as they will be updated when our API limits are updated.
|
384
405
|
|