Complex filter on query.

Hello everyone, here's the query :
db.query.ordersTable.findMany({
with: {
products: true,
user: {
columns: {
password: false,
},
},
},
where: and(
eq(ordersTable.draft, false),
or(
query === "" ? sql`TRUE` : undefined,
eq(ordersTable.id, Number(query) || 0),
ilike(sql`productsOrderTable.name`, `%${query}%`),
),
),
)
db.query.ordersTable.findMany({
with: {
products: true,
user: {
columns: {
password: false,
},
},
},
where: and(
eq(ordersTable.draft, false),
or(
query === "" ? sql`TRUE` : undefined,
eq(ordersTable.id, Number(query) || 0),
ilike(sql`productsOrderTable.name`, `%${query}%`),
),
),
)
I get the error : missing FROM-clause entry for table "productsordertable" I can't find a way to filter the orders according to the user or the products. For exemple I want the orders where the user name is "john". Or I want the orders where some of the products name contains "foo". PS : productsOrderTable has a column order_id as a foreign key I can only filter according to the ordersTable direct columns
0 Replies
No replies yetBe the first to reply to this messageJoin

Did you find this page helpful?