Using `.orderBy` in JSON
Hey,
I have a schema that roughly looks like this
and I want to query the db like that it gives me the top 10 Members with the highest
activity.messages
count. I figured out how I can orderBy but not inside of a json.Solution:Jump to solution
try something like:
```ts
const rows = await kysely
.selectFrom("member")...
25 Replies
Hey 👋
Are you using Kysely 0.26.x? what dialect are you using?
pg (postgres) and I use newest Kysely
In 0.26.x we've introduced type-safe JSON traversal, it's not documented yet in kysely.dev site, only in API docs and in the IDE.
Lemme know if this works for you:
https://kyse.link/?p=s&i=hKiV5qAL1BLLi3tvlwEq
will try when I’m home, than you :)
data:image/s3,"s3://crabby-images/b27c0/b27c07ab4082197483af5be6ad956a681c9b08dc" alt="think"
data:image/s3,"s3://crabby-images/6d38f/6d38fa54c4e60c5da7f44dece2b4a7115fec0fb8" alt=""
data:image/s3,"s3://crabby-images/4edd5/4edd56dc5dff32a7f07619617ab537027baadf87" alt=""
nvm was just vs code having it's moment
did it work?
process crashes with
If I comment the
.orderBy
away it worksdata:image/s3,"s3://crabby-images/5dca0/5dca0487c272b63c0f8ce611d0f09972a6e45ad0" alt=""
what postgres version?
pg (npm package) or postgres on the server?
server
PostgreSQL 14.8 (Ubuntu 14.8-0ubuntu0.22.04.1) on x86_64-pc-linux-gnu, compiled by gcc (Ubuntu 11.3.0-1ubuntu1~22.04.1) 11.3.0, 64-bit
I've added some test cases for json traversal in order by clauses https://github.com/kysely-org/kysely/pull/621 and everything seems to be OK.
we use pg 8.11.0 and postgres 15.x images.
@Igal I found the issue, in your example you used the
->
operator but it's ->>
, it works nowit should work with
->
too.
how's the column defined? json
or jsonb
?.addColumn("activity", "json", (col)
bingo, when changing the data type to
json
in tests it errors for order by with:
error: could not identify an ordering operator for type json
and works again when changing to ->>
.I already paniced because I didn't know what I should do and just randomly was scrolling through the test file and found the
->>
, tried it and worked lol
thanks anywayhttps://c.lunish.nl/r/4hU8WT.mp4 I am kind of lost here, why are the
activity.messages
higher on page 1 than on page 0? (each page only adds an offset [page] * 10
)->>
casts the thing you access to a string. The sorting is done using a stringified number. You probably need to explicitly cast to integerah okey, how do I do that (lol)
(@Igal^)
Solution
try something like:
yey that seems to work!! thank you