'TypeORM distinctOn with orderBy
I'm Trying to get the latest message for a user, Ether if he is the sender or the receiver But I can't use distinctOn with orderBy
const quiry = this.createQueryBuilder('message')
.orderBy('message.date', 'DESC')
.where('message.senderId = :id OR message.receiverId = :id',{id:user.id})
.distinctOn(['message.senderId','message.receiverId'])
const messages = await quiry.getRawMany();
SELECT DISTINCT ON ("message"."senderId", "message"."receiverId") "message"."id" AS "message_id", "message"."message" AS "message_message", "message"."date" AS "message_date", "message"."status" AS "message_status", "message"."senderId" AS "message_senderId", "message"."receiverId" AS "message_receiverId" FROM "message" "message" WHERE "message"."senderId" = $1 OR "message"."receiverId" = $2 ORDER BY "message"."date" DESC
SELECT DISTINCT ON expressions must match initial ORDER BY expressions
Solution 1:[1]
You can also try this way
const messages = this.createQueryBuilder('message')
.distinctOn('DISTINCT ON (message.senderId) as senderId, message.receiverId' as "receiverId")
.where('message.senderId = :id OR message.receiverId = :id',{id:user.id})
.orderBy('message.date', 'DESC').getRawMany()
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | sagar |
