Query
This page discusses how query
works.
Type Checks
import {
MetaTypeCreator,
ServerTimestamp,
NumericKeyRecord,
Removable,
createRef,
getDatabase,
query,
PushAbleOnly,
orderByValue,
endBefore,
startAt,
limitToFirst,
startAfter,
endAt,
limitToLast,
orderByKey,
orderByChild,
equalTo,
} from 'firesagejs'
export type Example = MetaTypeCreator<{
b:
| {
c: boolean | Removable
d: {
e: ServerTimestamp
}
}
| Removable
f: Record<string, 1 | 2 | 3 | 4 | 5>
i: NumericKeyRecord<boolean>
j: PushAbleOnly<{ k: null; l: { j: number } }>
}>
const exampleRef = createRef<Example>(getDatabase()) // firesage ref
/*
=======
OK
=======
*/
query(
exampleRef('f'),
orderByValue(),
// 1st argument type is the type of node 'f' child
// 2nd argument is optional, the type is type of key
// the type of key can only be numeric string or non-numeric string
// in this case the type of 2nd argument is numeric string because the type of 'f' is Record<string, 1 | 2 | 3 | 4 | 5>
startAt(1, 'xyz'),
endBefore(5),
limitToFirst(2)
)
query(
exampleRef('i'),
orderByKey(),
// when orderbyKey, the type of 1st argument is the type of key
// the type of key can only be numeric string or non-numeric string
// in this case it is numeric string because the type of 'i' is NumericKeyRecord<boolean>
// no 2nd argument
startAfter('24'),
endAt('100'),
limitToLast(5)
)
query(
exampleRef('j'),
// relative path must start at grandchildren which is 'k','l' and 'l/j'
// 'l' however is not valid because the type of 'l' is object literal and cannot be ordered
orderByChild('l/j'),
// 1st argument type is the type of node 'l/j' child
// 2nd argument is optional, the type is type of key
// the type of key can only be numeric string or non-numeric string
// in this case the type of 2nd argument is numeric string because the type of 'f' is Record<string, 1 | 2 | 3 | 4 | 5>
equalTo(1, 'abc')
)
/*
=======
not OK
=======
*/
query(
// can only order by node with one signature children
// b has 2 children with different signatures
exampleRef('b')
)
query(
exampleRef('f'),
// must has one orderBy to use cursor
startAt(1)
)
query(
exampleRef('f'),
orderByValue(),
// not ok, duplicated cursor
startAt(1, 'xyz'),
startAt(1, 'xyz'),
limitToFirst(2)
)
query(
exampleRef('f'),
orderByValue(),
// not ok, you cant combine startAt and startAfter
startAt(1, 'xyz'),
startAfter(1, 'xyz'),
limitToFirst(2)
)
query(
exampleRef('f'),
orderByValue(),
// not ok, you cant combine endAt and endBefore
endAt(1, 'xyz'),
endBefore(5),
limitToFirst(2)
)
query(
exampleRef('f'),
orderByValue(),
// not ok, you cant combine equalTo and any other cursor
equalTo(1, 'xyz'),
endBefore(5),
limitToFirst(2)
)
query(
exampleRef('f'),
orderByValue(),
startAt(1, 'abc'),
// not ok, incorrect value type, expect number
endBefore(true),
limitToFirst(2)
)
query(
exampleRef('i'),
orderByKey(),
// not ok, orderByKey don't need 2nd argument
startAfter('24', 'someKey'),
endAt('100'),
limitToLast(5)
)
query(
exampleRef('i'),
orderByKey(),
// not ok, when orderByKey the 1st argument must be the type of key
// in this case, expect numeric string
startAfter(false),
endAt('100'),
limitToLast(5)
)
query(
exampleRef('j'),
// not ok, path must start at grandchild path
orderByChild('childPath')
)
query(
exampleRef('j'),
// not ok, type of 'j/${string/}l' is object literal and cannot be ordered
orderByChild('l')
)
data:image/s3,"s3://crabby-images/b300b/b300bcf6e7b29ca7e37692e3b85143d79f63ebb9" alt=""
data:image/s3,"s3://crabby-images/2b8cc/2b8cc2e64ee2a9dce015eb730c3daacb80c2cc19" alt=""
data:image/s3,"s3://crabby-images/67476/674764f0ee9a0da45fe57a0499b3319829a1fadc" alt=""
Understanding Error Messages
note
We can only query index signature.
The value type for all keys must be the same, example: Record<string, T>
.
If you have data type like {a:number, b:boolean, c:string, d:boolean, e:string}
, it doesn't make sense to order them.
RTDB wont throw error if we violate this rule but this not a good practise.
We should always group similar things together.
data:image/s3,"s3://crabby-images/4817e/4817e6ab5d848f1528274712b5ba02f3627c946c" alt=""
data:image/s3,"s3://crabby-images/1a058/1a0584e7152de6bc63fc43a1d7876588a79e16b1" alt=""
data:image/s3,"s3://crabby-images/26cd5/26cd532a1e55773a00eb2caa56267abf8c3b8f3b" alt=""
data:image/s3,"s3://crabby-images/ff3da/ff3da4d4d70cec58e7416f631cbbdd9f1d8189e2" alt=""
data:image/s3,"s3://crabby-images/9e1f3/9e1f3682eaeb239269fe269d442ca99fc6894833" alt=""
data:image/s3,"s3://crabby-images/0485c/0485cc42ba2a305bd0d9e506fc39f848ad668c71" alt=""
data:image/s3,"s3://crabby-images/f66c3/f66c30e4afa45e3fc4216fb50820f6e48f25fd30" alt=""
data:image/s3,"s3://crabby-images/fd0e4/fd0e4f44055d7057f646fcf7ca3b4b091422319f" alt=""
data:image/s3,"s3://crabby-images/35965/3596504badfdd8ea292e1cd3d7610f8e86901568" alt=""
data:image/s3,"s3://crabby-images/570ab/570ab0a64619547459a122a3c15edf20339ff6a6" alt=""
data:image/s3,"s3://crabby-images/3cad1/3cad16dd13c9fbc521ab4104fe4d609f72133903" alt=""
data:image/s3,"s3://crabby-images/3ec53/3ec53561e2f0c2381083b0a383bbb0e7d110a611" alt=""
data:image/s3,"s3://crabby-images/242cd/242cdab15f0ed7c52f58b453acdc6f5c71c069db" alt=""